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Introduction 


The MB86292 (code name: Orchid; hereinafter referred to as Orchid) application notes are compilation 
of information related to circuit designs and graphics programming for users to refer to when using the 
graphics display controller Orchid or Fujitsu’s MB86290 series graphics driver to design software and 
hardware. 


Always verify operations before using the circuit and programming examples described in this 
document. 
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1. CONNECTION EXAMPLE FOR EACH INTERFACE 


1.1 Connecting to Host CPU 


Orchid can be connected with Fujitsu’s SPARClite, Hitachi’s SH4 and SH3 and NEC’s V83X with MODE 
[0:1], without an external circuit. 


The MODE2 pin enables you to select “Normally Not Ready” or “Normally Ready” for the action of the 
ready signal. 


You must set Orchid to the software space being mapped that is proper for the ready signal mode (The 
software should be set to 1 in the “Normally Not Ready” mode; the software should be 2 in the “Normally 


Ready” mode). 
Refer to the MB86292 <Orchid> Specifications Manual for details of the ready signal. 
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1.1.1 Example connection with SH3 and SH4 


SH3, SH4 Orchid 


D[31:0] D[31:0] 


100 KQ 


MODE[1:0] 


XRESET 


Fig.1 Example Connection with SH3 and SH4 


e The RC connection in the above figure is an example for pulse inputs to the S pin higher than 500 nsec. 


A Low level higher than 300 us is required in the XRESET pin after the S pin is set at a High level, so it 
is recommended that the CPU RESET pin input be input directly to the XRESET, as shown in the above 
diagram (For SH, a Low level of 10 msec is retained at power on). 


e Set the DMAC register to output DREQ as Low active and DRACK and DACK as High active. 


e XRDY output is “Hi-Z,” when CS is not active, so it is recommended that a Pull-Down (or Pull-up for 
SH3) be setup for the RDY signal line on the outside of the chip. 


¢ To enable a WAIT by the XRDY, insert it into the area the Orchid was mapped by the WCR2 register for 
the MODE2 pin and set a software WAIT 1 or 2. 
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1.1.2 Example connection with V83X 


V83X Orchid 


D[31:0] D[31:0] 
A[23:2] A[23:2] 
MWR 


DMAAKn 


INTPn 


MODE[1:0] 


100 KQ 


XRESET 


Fig.2 Example Connection with the Video Interface Unit 


e The RC connection in the above figure is an example for pulse inputs to the S pin higher than 500 nsec. 


A Low level of higher than 300 us is required in the XRESET pin after the S pin is set at a High level. 
To activate the V83X with the PLL mode, it is recommended that the CPU RESET pin input be input 
directly to the XRESET, as shown in the above figure (In the PLL mode, a Low level of 10 msec is 
retained at power on to allow the PLL to stabilize). 


e The DMARQn should be low active; DMAAKn should be high active. Select TC for the TC/STOPAK 
dual use pin, then set the V83X register to end transfers at a Low signal. 


e¢ XRDY output is “Hi-Z,” when CS is not active, so it is recommended that a Pull-Down be setup for the 
XRDY signal line on the outside of the chip. 


¢ To enable a WAIT by the XRDY, insert it into the area the Orchid was mapped by the PWC register for 
the MODE2 pin and set a software WAIT 1 or 2. 
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1.1.3 Example connection with SPARClite 


SPARClite Orchid 


D[31:0] D[31:0] 


A[23:2] A[23:2] 


A24 


CLKIN BCLKIN 


AS# XBS 
CSn# XxCS 


RDWR# XRD 
BE[3:0] XWE[3:0] 


READY# XRDY 


DREQ 
DTACK 
DRACK 
XINT 
Sparc : 11 


MODE[1:0] 100 Ko. 


A Low level of higher than 300 us required XRESET 
after the S pin set at a High level 


Fig.2 Example Connection of V83X and Orchid 


e The RC connection in the above figure is an example for pulse inputs to the S pin higher than 500 nsec. 
¢ Because No DMAC is provided on SPARClite, the DMA pins are open and are set to a low clamp. 


¢ XRDY output is “Hi-Z,” when CS is not active, so it is recommended that a Pull-Down be setup for the 
XRDY signal line on the outside of the chip. 
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1.2 Connection Example for the Video Interface Section 
1.2.1 Example connection with MB3516A 


Scarlet MB3516A 


AAA R-OUT 
| WW» G-0uT 
| _W\+ B-OUT 


VW V-OUT 
[WV y-ouT 


CSYNC-IN 


NTSC/PAL 
[VW c-ouT 
ACOMPR pen 
ACOMPG 
ACOMPB 
2.7 KO 
14.31818 MHz 


Note 1) Vertical resolution is relatively higher for the interlacing and video mode but the screen may 
flicker. To prevent the screen flickering, use the non-interlacing mode. 
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1.3 Example Connection for the Memory Interface Section 


Orchid 


MD[63:0] 
MA[11:0] 
MDQM{7:0] 


MRAS 
MCAS 
MWE 


e The above figure is an example of four connections of 16 Mbit x 16 FCRAM. Orchid can be set to Row 
and Column and Bank with the MMR (memory mode register) so it can be used by simply connecting to 
an address. 
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Orchid 


Example External Connection of the Memory Clock Signal 


e Orchid has been designed to allow you to use it directly with the memory. However, there may be the 
need to make fine timing adjustments that depend on the board layout. 


In such cases, it is recommended that the memory clocks be laid out as shown in the above figure. 


Note that the resistor in series is inserted for the noise prevention, and the resistor connected to the 
power and ground, and the capacitor are inserted for timing adjustments. 
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2. STARTING UP ORCHID 


2.1 Setting Memory Interface 


It is necessary to always set the MMR register (memory interface register) before setting the display and 
drawing when starting up Orchid. 


Refer to Section 1.5.7 in the MB86292<Orchid> Specifications Manual for an example of the MMR 
settings. 

2.2 Transferring Display List 

On Orchid, a display list is transferred to the built-in FIFO to process drawing. 


There are three ways to transfer display lists. 
e DMA transfer (Main memory => Orchid’s built-in FIFO) Only on SH4 and V83x. 
e Local transfer (Graphic memory => Orchid’s built-in FIFO) 
e CPU transfer (CPU => Orchid’s built-in FIFO) 


2.2.1 Executing a display list using the graphics driver 
There are two modes to execute the display list with the graphics driver. 


e Synchronized Mode: Mode to transfer display lists each time driver function related to the drawing 
processing is executed. This mode is mainly used when debugging software. 


e Asynchronized Mode: Mode to transfer display lists that has been stacked on the memory until that 
time at any timing. There are two types of functions to start the transfer of display lists. 
Function Name: GdcFlush(): Function that exits immediately after starting to transfer display lists. 
Function Name GdcSync (): Function that waits for the drawing processing to end after starting to 
transfer display lists 


The following shows an example program. 


/* In synch mode */ 
GdcExecMode ( GDC_ENABLE ); 


GdcSetAttrLine (GDC_LINE_WIDTH,GDC_LINE_WIDTH_5); 


GdcSetLinePattern ( OxOOOOFFFF ); 
GdcPrimType ( GDC_LINES_FAST ); 
GdcDrawVertex2D ( 0x01000000, 0x00100000 ); 
GdcDrawVertex2D ( 0x01000000, 0x00100000 ); 
GdcPrimEnd ( ); 


/* In asynch mode */ 
GdcExecMode ( GDC_DISABLE ); 


GdcSetAttrLine (GDC_LINE_WIDTH,GDC_LINE_WIDTH_5 ); 
GdcSetLinePattern ( OxOOOOFFFF ); 

GdcPrimType ( GDC_LINES_FAST ); 

GdcDrawVertex2D ( 0x01000000, 0x00100000 ); 
GdcDrawVertex2D ( 0x01000000, 0x00100000 ); 
GdcPrimEnd ( ); 

GdcFlush ( ); 


/* In asynch mode (waiting end of drawing processing) */ 
GdcExecMode ( GDC_DISABLE ); 

GdcSetAttrLine (GDC_LINE_WIDTH,GDC_LINE_WIDTH_5); 
GdcSetLinePattern ( OxOOOOFFFF ); 

GdcPrimType ( GDC_LINES_FAST ); 

GdcDrawVertex2D ( 0x01000000, 0x00100000 ); 
GdcDrawVertex2D ( 0x01000000, 0x00100000 ); 
GdcPrimEnd ( ); 

GdcSync ( ); 
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/* Set to synch mode */ 
/* Transfers display list for register setting 1 */ 
/* Transfers display list for register setting 2 */ 


/* Transfers display list for dram command 3 */ 


/* Set to asynch mode */ 


/* Batchs display list transfer */ 


/* Set to asynch mode */ 


/* Batchsdisplay list transfer and waits for drawing 
engine processing to end */ 


The procedures for the DMA transfer using the driver function, the local display transfer and the CPU 
transfer is set by using the GdcFlushDisplayList () function. Refer to the MB86290 Series Graphic 


Driver User’s Manual for details. 
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2.2.2 Executing display list 
The following is an example program for transferring using CPU write, DMA, and local transfer. 


Note that the following are the functions in the example program. 


void wrb(unsigned long addr, unsigned char data) { /* byte write */ 
unsigned char *paddr = ((unsigned char *) addr); 
*padadr = data; 

} 

void wrw(unsigned long addr, unsigned short data) { /* word write */ 
unsigned short *paddr = ((unsigned short *) addr); 
*padadr = data; 

} 

void wrl(unsigned long addr, unsigned long data) { /* long word write */ 
unsigned long *paddr = ((unsigned long *) addr); 
*padadr = data; 


2.2.3 CPU write transfer (Main Memory => FIFO) 
It is possible to write the program from each CPU to Orchid to transfer the display lists. 


To execute drawing by writing the program from the CPU, program it so as to write to the FIFO if there is 
more than half of the FIFO capacity remaining. 


2.2.4 DMA transfer (Main Memory => FIFO) 


Orchid supports each CPU single addresses and dual address DMA transfers. The DSU register for the 
host interface register group is used to set the procedure for transfer. 


When using SH3, transferring display lists to the Orchid FIFO using DMA is prohibited. There is no 
problem in transferring to the graphics memory. 


Furthermore, when using SH4 or V83x, insert an interrupt command after the display list and perform 
DMA transfer. Do not access the Orchid register or the graphics memory until the interrupt has been 
generated from Orchid. 


2.2.4.1 When using SH4 


<Setting Example Conditions> 
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e Uses the P2 region as the logic space 


e Maps Orchid in CS4 as the physical space 


e Already have written display list to physical space C3. 


e Uses DMA channel 1 


#define SAR1 OxFFA00010 
#define DAR1 OxFFA00014 
#define TCR1 OxFFA00018 
#define CHCR1 OxFFA0001C 
#define DMAOR OxFFA00040 
#define GDC_DSU 0xB1FC0004 
#define GDC_DTC 0xB1FC0000 
#define GDC_DRQ 0xB1FC0018 
[rotate tae ieee eee 


wrb ( GDC_DSU,0x02 ); 
wrl ( CHCR1, 0x00001241 ); 


wrl (DMAOR, 0x00000001 ); 
wrl (SAR1, OxAC000000 ); 
wrl (DAR1, 0xB1FFO4A0 ); 
wrw ( TCR1, 0x1000 ); 


wrw ( GDC_DTC, 0x1000 ); 
wrb (GDC_DRAQ, 0x01 ); 


/* DMA source address register 1 */ 

/* DMA destination address register 1 */ 
/* DMA transfer count register 1 */ 

/* DMA channel control register 1 */ 

/* DMA operation register */ 


/* Scarlet DMA setup register */ 
/* Scarlet DMA transfer count register */ 
*/ Scarlet DMA request register */ 


/* Sets DMA transfer mode */ 

/* Fixes DRAK, DACK hi-active, destination address, and increase 
source addresses, external request, single address mode, 32 byte 
transfer */ 

/* DMA startup allowed */ 

/* DMA source address 0xAC000000 */ 

/* DMA destination address DrawBase + 4A0 (DFIFO) */ 

/* DMA transfer count 0x1000 */ 


/* DMA transfer count 0x1000 */ 
/* DMA startup */ 
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2.2.4.2 When using V83X 

<Setting Example Conditions> 
e Maps Orchid to block 3 (CS3) in the memory space 
e Display list 
e Uses DMA channel 0 


#define V_DSAOH 0xC0000030 /* DMA source address register 0 High */ 
#define V_DSAOL 0xC0000032 /* DMA source address register 0 Low */ 
#define V_DDAOH 0xC0000034 /* DMA destination address register 0 High */ 
#define V_DDAOL 0xC0000036 /* DMA destination address register 0 Low */ 
#define V_DBCOH 0xC0000038 /* DMA byte count register 0 High */ 

#define V_DBCOL 0xC000003A /* DMA byte count register 0 Low */ 

#define V_DCHO 0xC000003C /* DMA byte count register 0 Low */ 

#define GDC_DRQ 0x53fc0018 /* Scarlet DMA request register */ 

#define GDC_DSU 0x53fc0004 /* Scarlet DMA setup register */ 


wrw_lO(V_DSAOH, (short)(gloDmaSAR1 >> 16)); /* Sets transfer source address */ 
wrw_lO(V_DSAOL, (short)(gloDmaSAR1)); 


wrw_lO(V_DDAOH, (short)(gloDmaDAR1 >> 16)); /* Sets transfer destination address */ 
wrw_lO(V_DDAOL, (short)(gloDmaDAR1)); 


wrw_lO(V_DBCOH, (short)((glbDmaTCR1-1) >> 14)); /* Sets transfer count */ 
wrw_lO(V_DBCOL, (short)((gloDmaTCR1-1) << 2)); 


wrw_lO (V_DCHCO, 0x00a5); /* Set channel transfer mode */ 
wrw_lO(V_DC, 0x0001); /* Control DMA transfer mode */ 
wrb (GDC_HOST_DSU, 0x02 ); /* Sets DMA transfer mode */ 
wrb (GDC_HOST_DRQ, 0x01 ); /* Starts up DMA */ 


Note) | When selecting the CPU mode for V83x (MODE[1:0]=0x2), instead of counting DMA transfers 
on Orchid, it checks for the end of the transfers with the XTC signal from V83x. For that reason, 
it is not necessary to set the DTC register in the Orchid host interface register group. 
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2.2.5 Local transfer (Graphic Memory => FIFO) 


This allocates any space in the graphics memory as the display list region and after storing the display 
list, Orchid reads the display list sequentially. 


To use the local transfer, write Ox00000001 to the HostBase + 0x001ch. 


<Transfer example conditions> 
e Display list storage graphics memory has the base address: 0x00000000 
e Display list is stored in the graphics memory. 


e Memory space allocation has the same conditions as DMA transfer. 


#define GDC_LSA 0xB1FC0040 /* Orchid display list source address register */ 
#define GDC_LCO 0xB1FC0044 /* Orchid display list transfer count register */ 
#define GDC_LREQ 0xB1FC0048 /* Orchid display list transfer request register */ 
ee ee 
Reads the display list from the graphics memory 
Sat eeoi oe hee Bos SS oe es arb bess Sees oe gee ot es 2e ee eh ete see et es ae fee ee ek ay 
wrl (GDC_LSA, 0x00000000 ); /* Sets display list strange address on graphic memory */ 
wrl (GDC_LCO, 0x00001000 ); /* Sets display list transfer count */ 
wrb ( GDC_LREQ, 0x01 ); /* Starts up display list transfer */ 
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3. DISPLAY FUNCTION 


Orchid has a four hierarchical structured display screen, the lower two of which can be split into an M and 
B layer on the left and right. This enables the use of six logical display screens. Note that the M and B 
layers cannot be displayed on the right side (MR, BR) only. To display on one screen, use the ML and BL 
layers. 


Two hardware cursors are available as well as the six display screens. 


3.1 Setting Display Parameters 


3.1.1. Programming the horizontal and vertical directions 


It is necessary to set each type of register of the display control register group for the display resolution 
when using Orchid. The following shows an example register setting for each resolution. 


Resolution SC | HTP | HSP | HDP | HSW | VTR | VSP | VDP | VSW 
320 x 200 29 423 | 350 | 319 30 | 262 | 224 | 199 
320 x 240 29 423 | 350 | 319 30 | 262 | 244 | 239 
360 x 200 26 470 | 389 | 359 34 | 262 | 224 | 199 
400 x 200 23 529 | 435 | 399 38 | 262 | 224 | 199 
480 x 200 19 635 | 520 | 479 46 | 262 | 224 | 199 
640 x 400i 14 847 | 700 | 639 62 | 262 | 224 | 199 
640 x 480 7 799 | 655 | 639 95 | 524 | 489 | 479 1 
640 x 480i 14 847 | 700 | 639 62 | 262 | 242 | 239 2 
854 x 480 5 | 1061 |} 874 | 853 | 125 | 524 | 489 | 479 1 
800 x 600 4 | 1055 | 839 | 799 | 127 | 632 | 600 | 599 3 
1024 x 768 2 | 1388 | 1047 | 1023 | 1385 | 805 | 770 | 767 5 


MP }M}M}]_M}]M] PP 


‘’ represents Interlace. 


The sizes of the ML and MB and BL and BR layers when split are set using the HDB register (the register 
that sets the display period of the ML and BL registers). 


Refer to the MB86291 <Orchid> Product Specifications for details regarding definitions of HTP. 
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3.1.2 Programming logic image space 
To use multiple layers, set drawing frame size for each layer and memory addresses. 


The following shows an example setting. 


¢ Clayer: drawing frame size (640 x 480) 


C layer logic frame height (CH) 480 raster 

C layer logic frame memory width (CW) 10 (640 pixel) 

C layer color mode (CC) 8-bit indirect color 
C layer logic frame origin address (COA) 0x000000 

C layer display origin address (CDA) 0x000000 


C layer X direction display starting position (CDX) 0x0000 
C layer Y direction display starting position (CDY) | 0x0000 
C layer transparent color setting (CTC) Palette number 0 is transparent color. 


[Panwnnnn nnn nn nn= Driver setting example ---------------------------------------=----- N 
/*Sets display frame */ 
GdcDispDimension ( GDC_DISP_LAYER_C, GDC_ENABLE, GDC_DISP_8 BPP, GDC_FLIPMODE_0O, 


0, 0, 640, 480 ); /*C layer frame attribute */ 

/*Display starting position */ 
GdcDispPos ( GDC_DISP_LAYER_C, 0, 0, 0); /* Sets C layer display starting position */ 
GdcColorTransparent (GDC_DISP_LAYER_C, 0x0 ); /* Sets C layer transparent color */ 
GdcColorZeroMode(GDC_DISP_LAYER_C, GDC_COLOR_TRANSPARENT ); /* Sets color zero mode */ 
GdcColorPalette (GDC_C_LAYER_PALETTE, 0, 256, ucolorC ); /* Sets C layer palette */ 
[¥nnnnnnn nnn nnnn ne Register Setting Example ------------------------------------------ */ 
CM Reg { CC, CW, CDY Reg = 0x0000, CTC Reg = 0x8000 
[*onn-n-nn--n----- Sets palette register ------------------------------------------------- */ 


For (l=0;1< 256 ;1++){ 
CPAL (|) Reg = * ( ucolorC); 
ucolorC ++ ; 


} 


*Set logic frame height to size - 1. 
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e BL layer: drawing frame size (1280 x 960) 


BL layer logic frame height (BLH) 960 raster 

BL layer logic frame memory width (BLW) 20 (1280 pixels) 
BL layer display screen (BLFLP) Screen 0 

BL layer color mode (BLC) 8-bit indirect color 
BL layer logic frame origin address (BLOAO) 0x4b000 

BL layer display origin address (BLDAO) 0x4b000 

BL layer X direction display starting position (BLDX) 0x0000 

BL layer Y direction display starting position (BLDY) 0x0000 


[Pcosacr ec pnaadaseeua ds Driver setting example ---------------- tf 
/* Set display frame */ 


GdcDispDimension ( GDC_DISP_LAYER_BL, GDC_ENABLE, GDC_DISP_8 BPP, GDC_FLIPMODE_O, 0x4b000, 


0x4b000, 1280, 960 ); 
/* Display starting position */ 
GdcDispPos (GDC_DISP_LAYER_BL, 0, 0, 0 ); 
[* wnnnnnnnnnnnn ne Register setting example ------------------ sf 


/* Sets BL layer frame attribute */ 


/* Sets BL layer display starting position */ 


BLM Reg { BLC, BLFLP, BLW, BLH } = 0x001403BF, BLOAO Reg = 0x4b000, 
BLDAO Reg = 0x4b000, BLDX Reg = 0x0000, BLDY Reg = 0x0000 


* Set logic frame height to size - 1. 


e BR layer: drawing frame size (320 x 480) 


BR layer logic frame height (BRH) 480 raster 

BR layer logic frame memory width (BRW) 10 (820 pixels) 

BR layer display screen (BRFLP) Screen 0 

BR layer color mode (BRC) 16-bit indirect color 
BR layer logic frame origin address (BROAO) 0xE1000 

BR layer display origin address (BRDAO) 0xE1000 


BR layer X direction display starting position (BRDX) 0x0000 
BR layer Y direction display starting position (BRDY) 0x0000 


[*--------------------- Driver setting example ------------------------------------------- */ 

/* Sets display frame */ 

GdcDispDimension ( GDC_DISP_LAYER_BR, GDC_ENABLE, GDC_DISP_16_BPP, GDC_FLIPMODE_0, 0xE1000, 
0xE1000, 320, 480 ); /* Sets BR layer frame attribute */ 

/* Display starting position */ 
GdcDispPos ( GDC_DISP_LAYER_BR, 0, 0, 0 ); /* Sets BL layer display starting position */ 
[* -n------------------- Register setting example --------------------------------------- */ 

BRM Reg { BRC, BRFLP, BRW, BRH } = 0x800A03BF, BROAO Reg = 0xE1000, 
BRDAO Reg = 0xE1000, BRDX Reg = 0x0000, BRDY Reg = 0x0000 
* Set logic frame height to size - 1. 
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3.1.3 Setting overlay mode 


The results of overlaying the C layer and other layers can be o-blended. The following shows a setting 
example of the overlay blend mode. 


<Setting example> 
Overlay mode: Blend mode 
Blend coefficient: 0x80 


/* When using driver */ 
GdcOverlayPriorityMode (GDC_OVERLAY_C_BLEND ); /* Sets overlay display mode */ 
GdcOverlayBlend (GDC_ENABLE, 0x80 ); /* Sets blend coefficient */ 
/* Register setting example */ 
BMODE Reg = 0x0001 
BRATIO Reg = 0x0080 


* Blending is performed only when the C layer pixel is 1. 


3.1.4 Setting display control mode register 


<Setting example> 


Setting synch mode : Non-interlace 

Synch signal generation polarity : Negative logic output 

EO I/O format : Low level output with even numbered frames 
Scaling : 1/8 (25 MHz) 

Reference clock : Built-in PLL 

Display layers :C, ML, MR, BL, BR 


/* Sets display control mode register */ 
/* When using driver */ 
GdcDispClock ( 0x00000700 ) ; 
/* Register setting example */ 
DCM Reg { CKS, SC, EO, SF, ESY, SYNC } = 0x0700 
DCE Reg { DEN, BE, ME, WE, CE } = 0x800D 


* Display control mode must be set in the last step of the process for setting the display parameters. 


* The driver function GdcDispClock () is the driver function that sets the DCM register. The DCE 
register is set to each layer by the driver function GdcDispDimension () layer enable. 
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3.1.5 Screen scroll 


Screen scroll is performed by changing the X direction starting position, the Y direction starting position 
and the display origin address. 


The following shows a screen scroll programming example. 


<Program operation example > 
e BL layer has the same conditions as the BL settings described in Section 3.1.2. 
e BL layer scrolls 1 pixel from the right to the left for each time a vertical synch interrupt occurs. 


[osssctsccoeeese Screen scroll program example --------------------------- */ 
#define BLda 0x4b000 /* BL layer memory address */ 
#define Ldx 0 /* X direction moving amount */ 


#define Ldy 0 


/* Y direction moving amount */ 


/* When using driver */ 


void VSyncINT ( void ) /* VSYNC Interrupt */ 


GdcDispPos ( GDC_DISP_LAYER_BL, GDC_BANK_0, Ldx, Ldy ); 
Ldx = Ldx+1; 

Ldy = Ldy+0; 

if (Ldx > 1279) Ldx = 0; if (Ldy>479)Ldy = 0; 


GdcClearInterruptStatus ( OxFB ); /* Clears interrupt status */ 


/* When not using driver */ 


void VSyncINT ( void ) /* VSYNC Interrupt */ 


BLDAO Reg = Lda; BLDX Reg = Ldx; BLDY Reg = Ldy; 
Ldx = Ldx+1; 

Ldy = Ldy+0; 

if (Ldx > 1279) Ldx = 0; if (Ldy>479)Ldy = 0; 

Lda = Ldx + 1280 x Ldy + BLda ; 


IST Reg = Oxf /* Clears interrupt status */ 
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* The following shows the calculation of the display origin address. 
e For 16-bit color: 


DA=2xDX+64xWxDY+0OA 


e For 8-bit color mode: 
DA =DX+64xW xDY+OA 


OA: logic frame origin address 
DA: Display origin address 

W: Logic frame memory width 

DX, DY: Display origin coordinates 


20 


me) 
FUJITSU 


3.1.6 Flipping display 


There is a flipping method automatically performed by Orchid and a method performed according to the 
user settings. 


The following shows examples of these methods. 


3.1.6.1 Automatic flipping by orchid 
Alternately displays screen 0 and screen 1 of any desired layer for each frame. 
This method enables smooth animation. 
<Program example conditions> 
e Alternately displays screen 0 and screen 1 of the BL layer. 
e BL layer frame size 640 x 480 
e Mapping of the BL layer screen 0 drawing frame address to 0x00000. 
e Mapping of the BL layer screen 1 drawing frame address to 0x96000. 


e Change the screen to draw for each vertical synch interrupt 
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[osteanseete a Flipping program example --------------------------- */ 
/* When using driver */ 


void DISP_INIT ( void ) { /* Initial setting of display parameter */ 


GdcDispDimension ( GDC_DISP_LAYER_BL, GDC_ENABLE, 16BPP_FORMAT, GDC_FLIPMODE_AUTO, 


0x00000000, 0x96000, 640, 480); /* BL layer automatically set to flip mode */ 
} 
void VSynclNT ( void ) { /* VSYNC Interrupt */ 
if ( flag ) GdcDrawDimension ( GDC_16BPP_FORMAT, 0x00000, 640, 480 ); 
/* Sets draw screen to screen 0 */ 
else GdcDrawDimension ( GDC_16BPP_FORMAT, 0x96000, 640, 480 ); 


/* Sets draw screen to screen 1 */ 


flag = to flag 
} 


/* When not using driver */ 
void DISP_INIT ( void ) { /* Initial setting of display parameter */ 


BLM Reg { BLC, BLFLP, BLW, BLH } = 0xC02803BF, BLOAO Reg = 0x000000, 
BLOA1 Reg = 0x96000 


} 
void VSynclNT ( void ) { /* VSYNC Interrupt */ 


if (flag) | FBR Reg = 0x00000, XRES Reg = 0x00000280 
else FBR Reg = 0x96000, XRES Reg = 0x00000280 


flag = to flag 
} 
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3.1.6.2 Flipping by user settings 


Flips screen 0 and screen 1 of any desired layer at any timing. 
Using this method performs flips without displaying graphics partially drawn. 
Note that the timing for flipping the actual screen is performed in synchronization with Vsync. 


<Program Example Conditions> 
e BL layer frame size 640 x 480 
e Mapping of the BL layer screen 0 drawing frame address to 0x00000. 
e Mapping of the BL layer screen 1 drawing frame address to 0x96000. 


e Draws screen 0 while displaying screen 1, then displays screen 0 after completing the 


drawing of screen 0. 


[*--------------- Flipping program example --------------------------- */ 
/* When using driver */ 
GdcDispDimension ( GDC_DISP_LAYER_BL, GDC_ENABLE, 16BPP_FORMAT, GDC_FLIPMODE_1, 
0x00000000, 0x96000, 640, 480); /* Displays BL layer screen 1 */ 
GdcDrawDimension ( GDC_16BPP_FORMAT, 0x000000, 640, 480 ) ; 
/* Sets draw screen to screen 0 */ 


GdcSync () ; /* Waits for drawing of display list and completion of that process */ 

GdcDispDoFlip (GDC_DISP_LAYER_BL GDC_BANK_0 ); /* Sets display screen to screen 0 */ 
/* When not using driver */ 

BLM Reg { BLC, BLFLP, BLW, BLH } = 0xA02803BF, BLOAO Reg = 0x000000, 

BLOA1 Reg = 0x96000, FBR Reg = 0x000000, XRES Reg = 0x0280 


while (CTR Reg PS = 01) {} /* Waits for pixel engine processing */ 
BLM Reg { BLC, BLFLP, BLW, BLH } = 0x802803BF 
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3.2 Setting Hardware Cursor 


Two hardware cursors of the size 64 x 64 (pixels) can be used. Color can only be used in 8 bit/pixel 
indirect color mode and the look up table uses the C layer color palette. 


Priority order for the C layer can be set independently for the two cursor displays. The portion of the 
cursor protruding from the screen is not displayed. 


The following shows a hardware cursor setting programming example. 


<Conditions> 
e Pattern data stored in the pointer curpat, curpat1 is loaded to 0x96000, 0x97000 on the graphics 


memory. 

PP cae eet nts ie a ie nt Dad i ete i hebben ot ied 
Cursor setting programming example 

pSsose ds sos ee ee ee ch deed ca ee seo a See ee es et * 
[*--n------------------ Driver use example ----------------------------------------- */ 
#define CURSOEO 0x96000 
#define CURSOE1 0x97000 
[*--------------- Program example --------------------------- */ 
GdcCursorAddres (0, CURSOEO ); /* Sets address that stores the cursor 0 pattern */ 
GdcCursorAddres (1, CURSOE1 ); /* Sets address that stores the cursor 1 pattern */ 
GdcCursorPos ( 0, 128, 256 ); /* Cursor 0 display position */ 
GdcCursorPos ( 1, 384, 256 ); /* Cursor 1 display position */ 
GdcCursorPriority (0, GDC_PRIORITY_CURSOR ); /* Sets priority display with the C layer */ 
GdcCursorPriority (1, GDC_PRIORITY_CURSOR ); /* sets priority display with the C layer */ 
GdcCursorColorTransparent ( 0x0 ); /* Sets cursor transparent color */ 
GdcCursorColorZeroMode (GDC_COLOR_TRANSPARENT ); //* Sets color zero mode */ 
GdcCursorPattern ( 0, curpat ); /* Loads cursor 0 pattern */ 
GdcCursorPattern ( 1, curpat2 ); /* Loads cursor 1 pattern */ 
GdcCursorDisplay (0, GDC_ENABLE ); /* Sets cursor 0 display */ 
GdcCursorDisplay (1, GDC_ENABLE ); /* Sets cursor 1 display */ 
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3.3 Video Capture Function 


Orchid can compress the video streams in compliance with ITU-RBT656 into any ratio, and read them to 
the graphics memory to display them in the W layer. 


3.3.1 Conversion into non-interlace 


There are two modes for converting video streams into non-interlace. They are the BOB and WEAVE 
modes. 


The BOB mode interpolates vertically the odd and even fields that enter every 1/60 sec for one frame. 
Frames are updated every 1/60 sec. 


The WEAVE mode merges odd and even fields that enter every 1/60 sec for one frame. For that reason, 
frames are updated every 1/30 sec. 


Because frames are updated every 1/60 sec in the BOB mode, this mode is good for displaying contents 
that comparatively have movement. Because the WEAVE mode has high vertical resolution, it is optimum 
for comparatively still displays. 
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3.3.2 Various parameters 


The following shows the various parameters from the original screen to display of the screen. 


+ — Wa —————»> 


(CIHSTR, CIVSTR) 


wb ———_> 


LoS 


hb 


| 


F (CIHEND, CIVEND) 
(a) Frame before being scaled (wahwb=HSCI + HSCF/2048, ha/hb= VSCI +VSCF/2048 


(Original Image) 


(b) Frame after being scaled 


Origin of video capture buffer(CBOA) 


s 


+ Buffer Stride ———_» 
« CIHEND-CIHSTR+1 


CIVEND-CIVSTR+1 
| 


(WX, WY) é; 


(C) Stored in capture buffer 
(BOB Mode) 


(D) Display image to screen 
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Origin of video capture buffer (C BOA) 


Stride of buffer (CBW) 
CIHEND-CIHSTR+1 


ww ——> 


CIVEND-CIVSTR+1 
(WH+ 172 


Even field 


o 
E 
a 
ei 
oi 
| 
bi 
nN 


To previous page (d) CF 


Even field 


(c) Store in capture buffer 
(WEAVE Mode) 


Processing with the Capture Scaler 

Compresses image to wb*hb size compared to the original image (wa*ha). Vertical and horizontal 
compression ratios are set with the CSC register’s VSCI, VSCF, HSCI, HSCF. Refer to Section 6.3 
in the MB86292 <Orchid> Specifications for details regarding methods of calculating setting values.. 
Also, the starting and ending points set by CIHSTR, CIVSTR, CIHEND and CIVEND are clipped at the 
frame after scaling and written to the buffer. 


Processing with the Buffer Controller 
Stores images passed through the buffer region scaler set by the CBOA/CBLA/CBW registers. The 
buffer is controlled using the ring buffer method. 


Processing with the Display Controller 

The display controller displays the data stored in the capture buffer in the W layer. The display 
controller always displays the latest captured frames. 

In the WEAVE mode, the display controller generates frames from the odd and even fields for display. 
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3.3.3 Synchronization of frames 


The capture buffer controller writes the sequentially captured rasters to the buffer. On the other hand, the 
display controller reads the captured-latest frames for display. The result is that frames can be skipped or 
the same frame can be displayed two or more times. 


1) When capturing faster than display in the BOB mode: 


Time ——> 


Capture 


i Absorbs time difference 
ZL 8 9 10 11 12 


Display 1 2 a pe ee 


-  N 7 skip 
rame Buffer state eer ite 
Display Ca F i 
pture 

Buffer size Digolay 4 Wrap around 
2.2 to 2.5 frames pointer 

Capture argin 

pointer 


In the operation as shown in the above figure, when the “Display pointer’ reaches the last of frame 4, if 
the “Capture pointer” reaches the last of frame 6, in the worst case, a frame can be skipped. This 
prevents the “Capture pointer” from passing the “Display pointer.” 


To avoid passing the “Capture pointer,” it is necessary to allocate enough margin to the buffer. 
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2) When capturing more slowly than display in the BOB mode: 


Time ——> 


Capture 1 2 3 4 5 6 7 8 9 10 | 11 12 


Mm 
Field k#——+| Absorbs time difference 


Display 1 2 3 4 4 5 6 7 8 9 10 11 12 


+> 
Fram Repeat 


3) When capturing faster than display in the WEAVE mode: 


Time ___=» 


Capture 1(0,e) 2(0,€) 3(0,e) 4(0,e) 5(0,€) 6(0,e) 7(0,€) 
4 p< 
Odd Even +——__—_-» Absorbs time difference 
Display 1 1 2 3 3 4 5 5 6 6 
<> 
Frame skip 


4) When capturing more slowly than display using the WEAVE mode: 


Time ____» 
Capture 1(0,e) 2(0,e) 3(0,e) 4(0,e) 5(0,e) 6(0,e) 


—M—— 
Field |} ——_—_———_- Absorbs time difference 


Display 1 1 2 2 2 3 3 4 4 4 5 5 
NIA 


Frame Repeat 
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3.3.4 Parameter setting values 
The following determines each parameter. 
The following are variable definitions. 
(xs, ys): Image read starting point 
(ws, hs): Original image size 
(wd, hd): Size to display in window 


= 
— 


Selecting non-interlacing 

The non-interlacing mode is determined by the input image format and the display output size. 
n: Raster count around the input image field. 

n= hd: BOB and WEAVE conversion unnecessary 

n<hd<2n: BOB or WEAVE 


When not using BOB and WEAVE, displays the odd field and even field alternately in the same 
position. However, in such cases, this is appropriate for displaying in comparatively small windows. 
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Setting compression rate 

Refer Section 6.3 in the MB86292 <Orchid> Specifications to set compression rate. 

rh = ws / wd 

rv = hs/ hd 

Compression rate integers are set to HSCI and VSCI. Fractions are set to HSCF and VSCF. 
HSCI * 2048 + HSCF = floor (rh*2048+0.5) 

VSCI * 2048 + VSCF = floor (rv*2048+0.5) 

“floor calculates the floor function (discard) of the value . 


& 


Setting image range to store in the capture buffer 

CIHSTR_ = floor(xs/rh+0.5) 

CIVSTR_ = floor(ys/rv+0.5) for not WEAVE mode 
= floor(ys/rv/2+0.5) for WEAVE mode 

CIHEND = CIHSTR+wa-1 

CIVEND =CIVSTR+hd-1 — for not WEAVE mode 
= CIVSTR+hd/2-1 for WEAVE mode 


= 


Setting capture buffer and W layer stride 
CBW = WW = ceil(wd/32 
*ceil calculates the ceiling function (round up) of the value . 


o 
aS 


Setting buffer size 
CBLA = CBOA + ceil(K*hd)*CBW*64 


K, here, shows the buffer size according to the frame size. This value is set to 2.5 from 2.2. K = 2.2 is 
a general value for use while K = 2.5 is a safer value. 


(ep) 
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Setting W layer parameter 
WW = xd 
WH = yd —1 
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3.3.5 Sample program 


This shows sample program when capturing a size of 640 x 480 with the BOB mode (with vertical 
interpolation). 


wonone When using a driver ------------- 

#define WIN_WIDTH 640 

#deifne WIN_HEIGHT 480 

/* Set W layer dimension */ 

GdcDispDimension(GDC_DISP_LAYER_W, GDC_ENABLE, GDC_16BPP_FORMAT, 
GDC_FLIPMODE_0,0x151800, 0x151800, WIN_WIDTH, WIN_HEIGHT); 


/* Set video capture parameter */ 

GdcCapSetWindowMode(GDC_CAP_YC_MODE, GDC_CAP_CAPTURE_MODE); 
GdcCapSetVideoCaptureBuffer(0x151800, (0x151800 + (640*480*2*2.2)),.640*2/64); 
GdcCapSetlmageArea(0,0,639,479); 


GdcDispTimingWindow(0, 0,WIN_WIDTH, WIN_HEIGHT); 
GdcCapSetVideoCaptureScale(0x0800, 0x0800); 

/* Start capture (NTSC) */ 

GdcCapSetVideoCaptureMode(GDC_CAP_START |GDC_CAP_ENABLE_V_INTERPOLATION| 
GDC_CAP_NTSC); 


n----- When not using a driver ------------- 
#define DISP_BASE 0xb1fd0000 
#define CAP_BASE 0xb1fd8000 
unsigned long val; 

unsigned long stride; 

unsigned long cap_height,cap_ size; 
stride = 640*2/64; 

cap_height = 480; 

cap_size = 640; 


val=*(unsigned int *)(DISP_BASE + 0x00); 
*(unsigned int *)(DISP_BASE + 0x00)=val | 0x00020000; //W On 


*(unsigned int *)(CAP_BASE + 0x14) = 0x151800; //CBOA 

(unsigned int *)( CAP_BASE + 0x18) = 0x151800 + (640*480*2*2.2)://CBLA 
*(unsigned int *)( CAP_BASE + 0x10) = stride<<16;//CBM 
( ) 
( ( 


* * 


* 


*(unsigned int *)( CAP_BASE + 0x1c) = 0x00000000;//CIHSTR 
unsigned int *)( CAP_BASE + 0x20) = ((cap_height)<<16) | cap_size;//CIHEND 


* * 


ewer TS a 


*(unsigned int *)( DISP_BASE + 0x18) = ( 0<<16) | 0;//WY,WX 

*(unsigned int *)( DISP_BASE + 0x1c) = ((cap_height-1)<<16) | cap_size;//WH, WW 
*(unsigned int *)( DISP_BASE + 0x34) = 0x151800;/WOA 

*(unsigned int *)( CAP_BASE + 0x04) = 0x08000800;//CSC 


*(unsigned int *)( DISP_BASE + 0x30) = 0xe0000000 | (stride<<16);//WM 
*(unsigned int *)( CAP_BASE + 0x00) = 0x83000000; //VCM 
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3.4 Display Performance 


Orchid can overlap 4 layers. However, when using high resolutions or capturing, there may be limitations 
to the count of layers and pixel data that can be displayed simultaneously according to the data supply 
capacity of the graphics memory. 
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4. DRAWING FUNCTION 


Orchid sets the draw register and executes the draw command by sending the display list to FIFO when 
drawing. 


If there is no particular specification regarding drawing attributes such as the drawing frame or color, the 
attributes set just before will be used. 


For that reason, there is no need to reset attributes for drawing primitives or for each drawing frame, but 
create programs in consideration of the relationships of attributes before and after. 


4.1 Setting Drawing Frame 


The display frame can be set for each layer; on the other hand the drawing frame is set as one current 
frame. For that reason, it is necessary to set the drawing frame when drawing. 


When setting the drawing frame, sets the color format, drawing frame base address and X direction 
resolution to the MDRO, FBR and XRES registers respectively. 


The following shows a drawing frame setting program example. Programs and display lists following this 
program example do not have draw frames set if not particularly necessary, so they are drawn to the 
drawing frames specified just before. 


< Conditions example > 
e Drawing frame address: 0x00000000, Resolution X-axis direction: 640. Y-axis direction 480 


¢ Color format is 16 bits/pixel 


GP ct el a ate ce ale ah a eal alae a ae ae atl apiece onan 

Drawing frame setting program example 

Et eh se ee ee a a ee Ee *} 

[*--------------------- Driver function usage example ----------------------------------------------- | 
GdcDrawDimension ( GDC_16BPP_FORMAT, 0x00000000, 0x0280, 0x01E0 ); /* Sets drawing frame */ 
[*--------------------- Display list usage example ------------------------------------------------- */ 

F1010108 /* Type: set register, data count: 1, address: 108 =>420 */ 

00008000 /* MDRO register direct color mode */ 

F1010110 /* Type: set register, data count: 1, address: 110 =>440 */ 

00000000 /* FBR register draw frame base address: 0x00000000 */ 
F1010111 /* Type: set register, data count: 1, address: 111 =>444 */ 

00000280 /* XRES register sets draw screen X axis direction resolution */ 
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4.2 Clearing Drawing Frame 


No particular commands or functions have been prepared for clearing the drawing frame on Orchid. Use 
the “rectangle region” for the drawing frame with any color to clear the drawing frame. 


Also, when clearing the C, W and M layers, filling with a set color as the transparent color will allow you to 
see the drawing on the lower heirarchy. 


4.3 Issuing Flash Commands 


When transferring the display list to Orchid, insert a flash command (frame buffer and Z buffer) after the 
display list. Issuing this command draws the drawing results remaining in the drawing pipeline to VRAM. 


/* Flash command issuing example /* 


Stacked display list 


0xFOC 10000 /* Frame buffer flash command */ 
0xFOC20000 /* Z buffer flash command /* 


4.4 Setting Clip Frame 


Specifying the clip frame in Orchid allows you to set it to not draw outside of the frame. Besides the clip 
for drawing (rendering), there is also a clip (view volume clip) for various conversions (geometry 
conversion). The view volume clip is described on another page. 


MDRO, CXMIN, CXMAX, CYMIN and CYMAX are the registers to set draw clip processing. 


The following page shows a draw clip frame setting program example. 
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[Rta BR eR 2a ce A IA a a tot de 
Clip frame setting program example 

So sreL sie st ee eet beh ee ete el ol ee ee ie a ee ee ee */ 

[Pnnnnnnn nn nn nnn nnnnnn Driver function usage example ---------------------------2nnn nnn nnn mene nnn oy 

GdcDrawClipFrame ( 0x0000, 0x0032, 0x0280, 0x0190 ); /* Sets clip frame */ 


GdcSetAttrMisc ( GDC_CLIP, (GDC_CLIP_X_ON | GDC_CLIP_Y_ON)); /* Sets clip processing enabled/disabled */ 


[* ----2-2-2-2-2- 2-2-2222 Display list example --------------------------------------------------------- */ 
F1040115 /*Type: set register, data count: 4, address: 115 =>454 */ 
00000000 /* CXMIN register sets clip frame X minimum value */ 
00000280 /* CXMAX register sets clip frame X maximum value */ 
00000032 /* CYMIN register sets clip frame Y minimum value */ 
00000190 /* CYMAX register sets clip frame Y maximum value */ 
F1010108 /* Type: set register, data count: 1, address: 108 =>420 */ 
00008300 /* MDRO register sets X, Y direction clip processing */ 


Note that the rendering engine outside of the draw clip frame draws pixels and has a circuit configuration 
that does not draw according to the clip judgement. For that reason, it is recommended set the view 
volume clip in a range near the drawing clip and to narrow the pixel range where the rendering engine 
operates. Refer to Section 4.6.2.4 in the MB86292 Specifications for details regarding the view volume 
clip setting. 
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1. View volume clip frame inappropriately set. Drawing far outside drawing clip frame. 


awing clip frame 


A View volume clip frame 


2. Drawing not drawn far outside drawing clip frame by view volume clip 
(drawn comparatively faster than 1.) 


Drawing clip frame ; . 
Drawing clip frame 


View volume clip frame View volume clip frame 


ei : Pixel range wherein rendering engine operates. 
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4.5 Bit Map Drawing (Binary Pattern) 


Bit map drawing uses 32 bit unsigned integers as the pattern format where 1 bit corresponds to 1 pixel. 
When the binary pattern is 1, it is drawn with the set foreground color, when 0, it is drawn with the set 
background color. It is possible to set not to draw the background using the register setting. 


It is possible to set the expand or compress mode with bit map drawing. Set these modes with the MDRO 
register’s BSH and BSV bits. Also, the foreground and background are set by the FC and BC registers. 


The following shows a bit map drawing program example. 


<Drawing > 
e Bit map foreground color: white; background color: no drawing 
e Pattern data: unsigned long type pointer stored in pat_ptr 
e Pattern size: 56 x 16 


| eee Driver function usage example ----------------------------------- A 
GdcBitPatternMode ( GDC_BPSCALE_H_EQUIV | GDC_BPSCALE_V_EQUIV ); 
/* Sets expand compress mode */ 


GdcColor (GDC_WHITE ); /* Sets foreground color */ 
GdcBackColor ( 0x8000 ); /* Sets background color */ 
GdcBitPatternDraw ( 320, 240, 56, 16, pat_ptr ); /* Binary pattern drawing */ 


Note: When drawing attributes are not set, those attributes set previously are used. 
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[Pascocetsecsacess Display list usage example ------------------ */ 
F1010108 /* Type: set register, data count: 1, address: 108 =>420 */ 
00008000 /* MDRO register bit map drawing vertical and horizontal ratio 1 */ 
F1020120 /* Type: set register, data count: 1, address: 120 =>480 */ 
00007FFF /* FC register sets foreground color */ 
00008000 /* BC register sets background color */ 
0B430022 /* Type: draw bit map P, Cmd: bit map, data count: 34 */ 
00F00140 /* Rys, RXs, pattern drawing starting point Y, X coordinates */ 
00100038 /* Rsize Y, RsizeX pattern data Y, X axes directions widths */ 
00000000 /* Pattern data */ 

32 pattern data 
00000000 /* Pattern data */ 


* 1 bit of the binary pattern format corresponds to the 1 pixel. With 32 bits, it is one pattern format. For 
that reason, in the above program, the X direction width of the pattern data is 56 pixels so two patterns of 
data are required per one line. Also, the Y direction axis is 16 pixels, so a total of 32 patterns (16 x 2) are 
required. 


pat_ptr[O]=OxXXXXXXXX, pat_ptr[1]=OxXXXXXXXX <= Two of these for 1 horizontal direction data 


T 


pat_ptr [1] lower 1 byte is invalid. 


Ex.: If the pattern data X direction width: 120: Y direction width: 20, the necessary data count is 120/32 = 
3.75 => 4 data per 1 horizontal direction. 


80 are required. 


The following shows the pattern data for 56 pixels in the X axis direction width and 16 pixels in the Y axis 
direction width. 


This pattern data is the character pattern written “Fujitsu.” 


static unsigned long pat_ptr[] = { 
0x00000000, 0x00000000, 0x00000000, 0x00000000, 
0x00000000, 0x00000000, Oxfe000810, 0x00000000, 
0x80000810, 0x00000000, 0x80000000, 0x10000000, 
0x80000000, 0x10000000, 0x80420810, 0x7e3c4200, 
Oxfc420810, 0x10424200, 0x80420810, 0x10404200, 
0x80420810, 0x103c4200, 0x80420810, 0x10024200, 
0x80460810, 0x10424600, 0x803a0810, 0x0e3c3a00, 
0x00000800, 0x00000000, 0x00007000, 0x00000000 }; 
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4.6 BLT and Rectangle Drawing 


There are types for rectangle drawing and transfer, described below. 

1. Rectangle region drawing using a single color 
Rectangle drawing by transferring between the graphics memory 
Rectangle drawing by transferring from the host CPU to the drawing frame 
Data transfer from the host CPU to the Orchid built-in texture memory 


OP 


Data transfer from the graphics memory to the Orchid built-in texture memory 
Logic operation processing and transparent processing can be set with the BLT function. 


Use the MDR4 register to set the logic operation processing and transparent processing, and use the 
TColor register to set the transparent color. 


4.6.1. Rectangle region drawing using a single color 
Clear each drawing frame and buffer using a single color filling. 
The following shows a rectangle region filling program example using a single color. 


<Drawing > 
e Draw color: White 
e Draw region: Draws the X, Y directions (60, 40) with (X, Y) = (320, 420) on the upper left 


[Pannnnnn nnn n enon nnnnn Driver function usage example ---------------------------n nn nn nemo nnn nnn nnn nn */ 
GdcSetAttrBlt (GDC_BLT_TILE, GDC_DISABLE ); 

/* Sets filling attributes when using rectangle region drawing */ 
GdcSetAttrBIt (GDC_BLEND_MODE, GDC_BLEND_COPY ); 

/* Sets filling attributes when using rectangle region drawing */ 


GdcColor (GDC_WHITE ); /* Sets filling color */ 

GdcBItFill ( 320, 240, 60, 40 ); /* Rectangle region drawing */ 
[*------------------ Display list usage example --------------------------------------------------------------- i 
F101010C /* Type: set register, set data count: 1, address: 10 =>430 */ 

00000000 /* Sets MDR4 register */ 

F1010120 /* Type: set register, set data count: 1, address: 120 =>480 */ 
00007FFF /* FC register sets drawing color */ 

09410000 /* Type: DrawRectP,Cmd: BItFill*/ 

00F00140 /* Rys, RXs, Y, X coordinates starting point to be drawn */ 
0028003C /* RsizeY, RsizeX Y, X direction sizes to be drawn */ 


Note: When drawing attributes are not set, those attributes set previously are used. 
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4.6.2 Rectangle region transfer drawing between graphics memory 

Transfers, copies and draws the rectangle region in the transfer origin to the transfer destination. 

By performing transparent processing, it is possible to not draw specified color pixels to the transfer 
destination. 

4.6.2.1 Copying within the same drawing frame 

Draws bit maps in the current drawing frame using rectangle transfer. 


<Drawing > 


e Transfers and copies rectangle regions drawn from the base frame starting point X, Y coordinates 
(10, 20) to the X, Y direction (60, 40) to the X, Y coordinates (290, 220). 


e Blend Mode: logic operation (EQUIV) 


JP eed sae Sree eaie Shee Sh peed Sop S eee pe Ea pee Sense Shee Sen eee DAHER een Ree eee coe 
Rectangle transfer drawing program (Copying within the same drawing frame) 

Peas DF eR ee IS AS et ee a ht et Ja ete “yf 
[*--------------------- Driver function usage example -------------------------------------------- */ 
GdcSetAttrBIt (GDC_BLEND_MODE, GDC_BLEND_ROP); //* Sets blend mode */ 
GdcSetRop ( GDC_ROP_EQUIV ); /* Sets logic operation mode */ 

GdcBltCopy ( 10, 20, 290, 220, 60, 40); /* Rectangle region drawing */ 

[*-------------------- Display list usage example -------------------------------------------------- sf 

F101010C /* Type: set register, set data count: 1, address: 10C =>430 */ 

00001300 /* Sets MDR4 register blend mode */ 

0D440000 /* Type: BltCopyP, Cmd: TopLeft */ 

0014000A /* SRYs, SRXs, transfer origin region Y, X coordinates */ 
00DC0122 /* DRYs, DRXs, transfer destination region Y, X coordinates */ 
0028003C /* BRsizeY, BRsizeX Y, X direction sizes of block to be transferred */ 


Note: When drawing attributes are not set, those attributes set previously are used. 
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4.6.2.2 Copying with any drawing frame 
Draws bit maps between any drawing frames using rectangle block transfer. 


<Drawing > 
e Perform a transparent copy (transparent color 0x7c00) 
e Transfer origin: Drawing frame address: 0x00000000 
Transfer origin rectangle top left X, Y coordinates: (10, 20) 
e Transfer destination: Drawing frame address: 0x00096000 
Transfer destination rectangle region top left X, Y coordinates: (30, 50) 
e Transfer block size: X direction: 60; Y direction: 40 


[Pass esct cnet ect oe ee es eee dene ee serene, 
Rectangle transfer drawing program (Copying between any drawing frames) 

pees Seb eee cee Se ee ee os es Se a ee el ees eee see a Py 
[*--------------------- Driver function usage example ------------------------------------------- */ 

GdcSetAttrBIt (GDC_TRANSPARENT_MODE,GDC_ENABLE ); /* Sets transparent mode */ 
GdcBltColorTransparent (Ox7C00); /* Sets logic operation mode */ 


GdcBltCopyAlt ( 10, 20 , 30, 50, 60, 40, 0, 640,0x96000, 640 ); 
/* Copies and draws rectangle region copy and draw */ 


[*------2------------ == === - Display list usage example -------------------------------------------- */ 

F101010C /* Type: set register, data count: 1, address: 10C =>430 */ 

00000002 /* MDR4 register sets transparent mode */ 

F10100A0 /* Type: set register, data count: 1, address: OAO =>280 */ 

00007c00 /* TColor register sets transparent color setting */ 

0F440000 /* Type: BitCopyAlternateP, Cmd: TopLeft */ 

00000000 /* SADDR Transfer origin drawing frame offset address */ 

00000280 /* SStride Transfer origin drawing frame X direction memory width */ 

0014000A /* SRYs, SRXs, Transfer origin drawing frame rectangle region top left Y, X coordinates */ 
0012C000 /* DADDR Transfer destination drawing frame offset address */ 

00000280 /* DStride Transfer destination drawing frame X direction memory width */ 

0032001E /* DRYs, DRXs, Transfer destination drawing frame rectangle region top left Y, X coordinates */ 
0028003C /* BRsizeY, BRsizeX Y, X direction sizes of block to transfer */ 


* At GdcBltCopyAlt, used when the data to draw is not duplicated at the transfer destination and transfer 
origin frames. 


* Color modes for the transfer origin and transfer destination must be the same. 


Note: When drawing attributes are not set, those attributes set previously are used. 
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4.6.3 Transfer, copy and draw to the VRAM from main memory 
Transfers and draws rectangle blocks from the main memory to the VRAM (frame buffer). 
Performing transparent processing enables not to draw specified color pixels to the transfer destination. 


<Drawing > 
e Transfer source: Pointer to pattern data on main memory: ptnptr 
e Transfer destination: Rectangle region starting point (X and Y) to copy with the current drawing 
frame: (20, 50) 
e Drawing size: X, Y Directions: (128, 128) 
e Blend mode: Source copy 


[Risen ee senses nck etre ions tee eat dace e dee seme gue teeioe ocean ed eee ph ae Se me cee eae eee eee cenmemued deme oaee Semmes 
Rectangle transfer drawing program (Copy from the main memory to the current drawing frame) 
RS a AS A a eo ee ee | 
[* --2--------- 22-2 ---------- Driver function use example ------------------------------------------------------- */ 
GdcSetAttrBit (GDC_BLEND_MODE, GDC_BLEND_COPY ); /* Blend mode setting */ 
GdcBltDraw ( 20, 50, 128, 128, ptnptr ); /* Rectangle area transfer and drawing */ 
[*------------------------ Display list use example ------------------------------------------------------------- ay 
F101010C /* Type: Set Register, data count: 1, address: 10C =>430 */ 
00000000 /* MDR4 register blend mode setting */ 
0B422002 /* Type: Draw Bit map P, Cmd: Bit Draw, data count: 8194 */ 
00320014 /* RYs, RXs, Transfer destination drawing frame rectangle area top left Y, X coordinates */ 
00800080 /* RsizeY, RsizeX Y, X direction sizes of block to transfer */ 
3E533E53 /* Pattern data */ 
8192 (128 x 128/2) patterns data 
3E533E53 /* Pattern data */ 


Note: When drawing attributes are not set specifically, those attributes set earlier are used as they are. 
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4.6.4 Transfer of texture and tile patterns from main memory 


Transfers texture and tile patterns from the main memory to the Orchid internal TexRAM and frame 
memory. 


4.6.4.1 Transfer to internal TexRAM 


The internal TexRAM is 8 KB. Up to one 64 x 64 pattern in 16 bit color format can be stored and up to 
two 64 x 64 pattern in 8 bit color format (in tiling) can be stored. Also, if the patterns are small, a multiple 
can be stored by specifying the corresponding addresses when drawing (for example, four with 32 x 32 
patterns). 


In texture mapping, using the internal TexRAM realizes faster drawing than placing Tex patterns on the 
frame memory. 


Tiling corresponds only to the internal TexRAM. 


<Program example> 
e Texpattern: Pointer: ptnptr1 (Size: 32 x 32), ptnptr 2 (Size: 16 x 16) 


ptnptr3 (Size: 16 x 16) 


| ee 
Stores 3 types of texture (tiles) patterns from the main memory to the internal texture memory. 
ocean oat eet ee a a So a te ee i ee */ 
[Panwa nnnnnn nnn nnnnnnn Driver function use example ----------------------------------2-c enc nnc enon monn cnnc nnn aff 


GdcTextureLoadint ( 32*32, ptnptr0, Ox0 ); 
GdcTextureLoadint ( 16*16, ptnptr1, 0x800 ); 
GdcTextureLoadint ( 16*16, ptnptr2, OxA00 ); 


[*-------------------- Display list use example ---------------------------------------------------------------- i) 
F101011B /* Type: Set Register, data count: 1, address: 11B =>46C */ 
00000000 /* TOA Register Pattern storage address setting */ 
11490200 /* Type: LoadTextureP, Cmd: LoadTex, data count: 200 */ 
XXXXXXXX /* Tex pattern from here */ 
{ 32 x 32/2 (When 16 BPP) data 
XXXXXXXX /* Tex pattern to here */ 
F101011B /* Type: Set Register, data count: 1, address: 11B =>46C */ 
00000800 /* TOA Register Pattern storage address setting */ 
11490080 /* Type: LoadTextureP, Cmd: LoadTex, data count: 80 */] 
XXXXXXXX /* Tex pattern from here */ 
{ 16 x 16/2 (When 16 BPP) data 
XXXXXXXX /* Tex pattern to here */ 
F101011B /* Type: Set Register, data count: 1, address: 11B =>46C */ 
00000A00 /* TOA Register Pattern storage address setting */ 
11490080 /* Type: LoadTextureP, Cmd: LoadTex, data count: 80 */ 
XXXXXXXX /* Tex pattern from here */ 
{ 16 x 16/2 (When 16 BPP) data 
XXXXXXXX /* Tex pattern to here */ 
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4.6.4.2 Transfer to frame buffer 
A maximum size of 256 x 256 texture pattern can be used by placing the Tex pattern on the frame buffer. 


Transferring texture patterns to the frame buffer uses the same method as described in Section 4.6.3. 
For that reason, after completing the transfer, it is necessary to return the FBR and XRES registers to 
their original settings. 


<Program example> 


¢ Tex pattern: Pointer: ptnptr1 (Size: 256 x 256) 


[*--------------------- Driver function use example ------------------------------------------- */ 
GdcTextureDimension(0x00f00000,256,256); 
GdcTextureLoadExt ( 256*256, ptnptr0, OxOf000000 ); 
Note: Before using the GdcTextureLoadExt function, set the size to transfer with the 
GdcTextureLoadExt ( 256 x 256, ptnptrO, OxO0f000000 ); GdcTextureDimension functions. 


[* 2-227-727-7222 20 == === - Display list use example ----------------------------------------- */ 
F1010113 /* Type: Set Register, data count: 1, address: 113 =>44C */ 
00000000 /* TBR Register Pattern storage address setting */ 
F1010119 /* Type: Set Register, data count: 1, address: 119 =>464 */ 
01000100 /* TXS Register Tex pattern size setting */ 

F1010110 /* Type: Set Register, data count: 1, address: 110 =>440 */ 
OFO00000 /* FBR Register Pattern storage address setting */ 
F1010111 /* Type: Set Register, data count: 1, address: 111 =>444 */ 
00000000 /* XRES Register X axis direction resolution setting */ 
0B428000 /* Type: Draw Bit map P, Cmd: Bit Draw, data count: 0x8000 */ 
00000000 /* Rys, RXs, Draw start coordinates setting of Y, X */ 
01000100 /* RsizeY, RsizexX Y, X drawing size setting */ 
XXXXXXXX /* Tex pattern from here */ 


} 256 x 256/2 data 
XXXXXXXX /* Tex pattern to here */ 
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4.6.5 Transfer and copy from texture pattern graphics memory to internal texture 
memory 


Temporarily stores texture patterns on the graphics memory. When using those texture patterns, drawing 
is faster by transfer copying them to the Orchid internal texture memory. 


Drawing attribute can not be set particularly. 
The following shows an example program. 


<Transfer > 
e Transfer source: Stored in the graphics memory address “0000”. 
e Transfer destination: Internal texture memory address “Ox800” 


Rectangle transfer program 
(Copy from texture pattern graphics memory to the internal texture memory) 


see ae a NR Rs orn 2 ek ss PR as ee tk Ns Pa ee ee Poe ay 

[*--n------------------ Driver function use example --------------------------------------------- */ 

GdcBltTexture ( 0x000000, 32, 0, 0, 32, 32, 0x800*); 

[*---------------------- Display list use example ------------------------------------------------- */ 

13490000 /*Type: BltTextureP,Cmd: LoadTile*/ 

00000000 /* SrcADDR Transfer source frame origin address */ 

00000020 /* SrcStride Transfer source frame X direction memory width */ 

00000000 /* SrcRectYs, Xs, Y, X coordinates from transfer source rectangle area top left origin */ 
00200020 /* BrsizeY, X Y, X direction sizes of the rectangle area */ 

00000800* /* DADDR Texture pattern storage destination offset address */ 
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4.7 Erasing Hidden Planes 


To erase hidden planes using the Z comparison on three-dimensional object drawing, use one frame 
memory as the Z buffer. 2 bytes of Z buffer area are required each 1 pixel of the same shape as the 
drawing frame. 


The Z value comparison method can be selected by setting the comparison calculation equation for the 
MDR1 and MDR2 registers. 


Note that a Z buffer clear command is not available as a display list. For that reason, use the BItFill 
command to clear the Z buffer. 


<Program example> 
e Memory address to use as the Z buffer: 0x00384000 
e Drawing frame size: 640 x 480 


/* When using driver function */ 
GdcBufferCreateZ(0x00384000); 
GdcBufferClearZ (); 


[Poaadeeceaddeeces- When using display list ------------------ */ 
OxF1010112 /* Type: Set Register, data count: 1, address: 112 =>448 */ 
0x0038400 /* ZBR Z buffer base address setting */ 
0xF1010120 /* Type: Set Register, data count: 1, address: 120 =>480 */ 
OxOO000FFFF /* FC Foreground color setting */ 
0OxF1010110 /* Type: Set Register, data count: 1, address: 110 =>440 */ 
0x00348000 /* FBR Drawing frame base set to Z buffer */ 
0x94100000 /* Type: DrawRectP, Cmd: BItFill */ 
0x00000000 /* RYs, RXs_ Y, X coordinates setting */ Executes clear 
0x01E00280 /* RsizeY, Rsizex Y, X area setting */ 
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4.8 Drawing Using Geometry Commands 


Orchid integrates a geometry engine that transforms vertex coordinates into the drawing (device) 
coordinates from object coordinates. 


4.8.1 Initializing the geometry engine 
For the first time of geometry process initialize the geometry engine after starting Orchid. 


The geometry engine is initialized by issuing a command. 


[iiss odenesasccenre When using driver function------------------ | 
GdcGeolnitialize(); 
eee When using display list ------------------- */ 


0x40000000 /*Type: G_Init */ 


4.8.2 Various parameters settings 


To use the geometry engine for drawing, it is necessary to set the following parameters in advance. 


4.8.2.1 Geometry attribute settings 


Sets the parameter attributes to process with the geometry engine. 

Corresponds to Orchid registers GMDRO to 2. 

Parameters to be set are shown below. 

¢ GMDRO register (Vertex geometry attribute setting) 

Sets using the driver function GdcGeoSetAttrMisc() and SetRegister command. 

Input data format 
Vertex color presence 
Z coordinates presence 
Texture coordinates presence 


¢ GMDR1 register (Line drawing geometry attribute setting) 
Sets using the driver function GdcSetAttrLine and SetRegister command. 
Broken line pattern reference position 
Ending point drawing mode setting 
Anti-alias mode setting 
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e GMDR2 register (Triangle drawing geometry attribute setting) 
Mode that can define triangle surface direction and does not draw back plane (back face curling). 
This function is enabled only in 3D. 
Sets using the driver function GdcGeoSetAttrSurf() and SetRegister command. 
Surface definition setting 
Back plane drawing setting 
Back face curling determines the front and back planes in the order of the vertex to be specified. 


Left-drawn Triangle Right-drawn Triangle 


NS?” NY? 


* Circled numbers show the specifying order of the vertex. 


Also, the method used to decide differs according to the Traingle_Fan and the Triangle_Strip 
commands. 


For Triangle_Fan (When front plane is set to be counterclockwise) 


(1) 


Always determines front and back planes 
in the specified triangle direction 


For Triangle_Strip (When front plane is set to be counterclockwise) 


(3) 


Triangle front and back planes are determined by: 
Triangles specified by an odd number: 

Register setting is front 
Triangles specified by an even number: 

The opposite of the register setting is front 
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4.8.2.2 Rendering attribute settings 
Sets the object attributes to be rendered. 
Corresponds to MDR 1 to 3. 

Parameters to be set are shown below. 


Note that the geometry and rendering attributes must both be set to the appropriate values. Refer to 
MB86291 Specifications for details. 


e MDR1 register (Line and point drawing attribute setting) 
Sets using the driver function GdcSetAttrLine() and SetRegister command. 


e MDR2 register (Triangle drawing attribute setting) 
Sets using the driver function GdcSetAttrSurf() and SetRegister command. 


e MDR3 register (Texture mapping drawing attribute setting) 
Sets using the driver function GdcSetAttrTexture() and SetRegister command. 


4.8.2.3 4x 4 Queue setting 
Sets the 4 x 4 queue to perform an MVP transformation (from an object coordinates to a clip coordinates). 
<Program example> 


e 4 x 4 Queue is stored in the float type pointer *mat. 


[*----------------- When using driver function -------------- */ 
GdcGeoLoadMatrixf(mat); 

[*------------------ When using display list ------------------ */ 
0x43000000 /*Type: G_LoadMatrix */ 
OxXXXXXXXX /*Matrix a0*/ 
OxXXXXXXXX /*Matrix a1*/ 
OxXXXXXXXX /*Matrix d2*/ 


OxXXXXXXXX /*Matrix d3*/ 


A separate program, “3D Graphics Library” is available to generate queues for MVP transformation. 


The pointer corresponding to the queue setting function GdcGeoLoadMatrix in the MB86290 Series 
Graphics Driver and the display list to load the queue to Orchid differ with regard to the lining up of the 
queue. 
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Lineup of queue and display list when loading the display list to Scarlet: 


G_LoadMatrix 4 Co 
mm 
Mf oe 
‘DO D1 D2 D3 AQ 8 = 
as Do 
BO bo 
Bi Do 
"Be Do 
a B3 2 DO 
¥ v 


not 
‘BO 
‘co Cl 


bo pi b2 bs 
yyy 


Driver use example 


Flaot Mat[] = { A0,B0,CO,DO, A1,B1,C1,D1, A2,B2,C2,D2, 
A3,B3,C3,D3} 
GdcGeoLoadMatrix(Mat); 


* Driver automatically changes lineup of queue when loading queue 
to Scarlet. 


50 


me) 
FUJITSU 


4.8.2.4 View volume clip setting 
Sets the clip boundary value in the view volume clipping to the X, Y, Z and W coordinates as required. 


Setting the view volume clip properly can reduce pixel drawing of no use and make drawing speed fast. 
See Section 4.4 and refer to MB86291 Specifications for details. 


Note that view volume clip can be turned ON and OFF. See section 5.7 and refer to MB86291 
Specifications for details. 


<Program example> 
GdcGeoViewVolumeXYClip (xmin, xmax, ymin, ymax); 


GdcGeoViewVolumeZClip (zmin, zmax); 
GdcGeoViewVolumeWClip (wmin); 


[*on-nn---2---2----- When using display list ------------------ | 
0x44000000 /* Type: G_ViewVolumeXYClip */ 
OxXXXXXXXX /*XMin*/ 

OxXXXXXXXX /*XMax*/ 
OxXXXXXXXX /*YMin*/ 
OxXXXXXXXX /*Y¥Max*/ 
0x45000000 /* Type: G_ViewVolumeZClip */ 
OxXXXXXXXX /*ZMin*/ 
OxXXXXXXXX /*ZMax*/ 
0x46000000 /*Type: G_ViewVolumeWClip */ 
OxXXXXXXXX /*WMin*/ 


51 


MB86292 ORCHID APPLICATION NOTE 


4.8.2.5 View port and depth range settings 


Sets the view port and depth range for transformation from the regular device coordinates to the drawing 
device coordinates as required. 


View port and depth range transformation transforms normalized coordinates (queue transformation, clip, 
3D-2D post conversion) to draw (device) coordinates. 


The following shows a detailed description of the calculation method. 


Xdc = Xndc * Xscale + Xoffset 
Ydc = Yndc * Yscale + Yoffset 
Zdc = Zndc * Zscale + Zoffset 


* Xdc to Zdc: Draw (device) coordinates 
Xndc to Zndc: Normalized device coordinates 
Xscale to Zscale: Scale values of X, Y and Z 
Xoffset to Zoffset: Offset values of X, Y and Z 


<Program example> 


[*------------------ When using driver function -------------- ss | 
GdcGeoNdcDcViewportCoeff (scalex, offsetx, scaley, offsety); 
GdcGeo NdcDcDepthCoef (scalez, offsetz); 


[*on-nn--n2--=-=-- == When using display list ------------------ */ 
0x41000000 /* Type: G_Viewport Command*/ 
OxXXXXXXXX /*X Scale*/ 
OxXXXXXXXX /*X Offset*/ 
OxXXXXXXXX IY Scale*/ 
OxXXXXXXXX I'Y Offset*/ 
0x42000000 /*Type: G_DepthRange Command*/ 
OxXXXXXXXX /*Z Scale*/ 
OxXXXXXXXX /*Z Offset*/ 
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4.8.3 Point drawing 


Issues point drawing command with the various settings to perform MVP transformation, geometry and 
rendering attributes set. 


<Program example> 
e Drawing color: White 
e Format: Flowing decimal 
/* When using driver function */ 
GdcColor(0x7fff); 
GdcGeoPrimType (GDC_POINTS); 
GdcGeoDrawVertex2Df( x, y); 
GdcGeo PrimEnd(); 


| ne When using display list ------------------ ‘ff 
0xF1010120 /* Type: Set Register, data count: 1, address: 480 =>FC */ 
0x00007FFF /* Drawing color setting */ 


0x21000000 /*Type:G_Begin Command:Points*/ 
0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float X */ 

OxXXXXXXXX /*float Y */ 

0x23000000 /*Type:G_End */ 
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4.8.4 Line drawing 


Issues the line drawing command with the various settings to perform MVP transformation, geometry and 
rendering attributes set. 


There are independent lines and continuous lines for line strip drawing commands for line drawing. 


Line geometry and drawing attributes are set with the GMDRO and 1 registers and MDR1 register. 


4.8.4.1 Multiple line drawing 


<Program example> 


Draws broken lines as continuous lines with the following attributes. 
e Drawing color: White 
e Line width: 5 pixels 
e Format: Flowing decimal 
e Line pattern: Ipat 
e Draws line portion (x0,y0,z0)=>(x1,y1,z1) and line portion (x2,y2,22)=>(x3,y3,z3) 


3, y3, 23 
(x0, yO, 20) wees) 


(x1, y1, 21) (x2, y2, 22) 


Fig. Drawing Example 


/* When using driver function */ 
GdcGeoSetAttrMisc(GDC_GEO_VTX_Z,GDC_ENABLE); 
GdcColor(Ox7FFF); 

GdcSetLinePattern(Ipat); 

GdcSetAttrLine(GDC_DEPTH_TEST, GDC_ENABLE); 
GdcSetAttrLine(GDC_DEPTH_FUNC, GDC_DEPTH_LEQUAL); 
GdcSetAttrLine(GDC_BROKEN_LINE, GDC_ENABLE); 
GdcSetAttrLine(GDC_LINE_WIDTH, GDC_LINES_WIDTH_5); 
GdcGeoPrimType (GDC_LINES); 

GdcGeoDrawVertex3Df( x0, yO, z0); 
GdcGeoDrawVertex3Df( x1, y1, 21); 
GdcGeoDrawVertex3Df( x2, y2, z2) 
GdcGeoDrawVertex3Df( x3, y3, z3) 
GdcGeo PrimEnd(); 


/* When using display list */ 


0OxF1012040 /* Type: Set Register, data count: 1, address: 8040 =>GMDRO */ 
0x00000004 /* Vertex parameter setting */ 

0xF1010120 /* Type: Set Register, data count: 1, address: 480 =>FC */ 
0x00007FFF /* Drawing color setting */ 

0xF1010123 /* Type: Set Register, data count: 1, address: 48C =>BLP */ 
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OXXXXXXXXX /* Broken line pattern setting */ 
0xF1010109 /* Type: Set Register, data count: 1, address: 424 =>MDR1 */ 
0x0408061C /* Line drawing mode setting */ 
0x21010000 /*Type:G_Begin Command:Lines*/ 
0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float xO */ 

OxXXXXXXXX /*float yO */ 

OxXXXXXXXX /*float z0 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x1 */ 

OxXXXXXXXX /*float y1 */ 

OxXXXXXXXX /*float z1 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x2 */ 

OxXXXXXXXX /*float y2 */ 

OxXXXXXXXX /*float z2 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x3 */ 

OxXXXXXXXX /*float y3 */ 

OxXXXXXXXX /*float z3 */ 

0x23000000 /*Type:G_End */ 


Terminate drawing with the G_End command temporarily when the vertex (x1, y1) has been sent in order to change 
color attributes with the line portion (x0,y0)=>(x1,y1) and the line portion (x2,y2,)=>(x3,y3). Then, draw 
the line portion (x2,y2,)=>(x3,y3) with G_BeginCont to process at high speed. 
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4.8.4.2 Consecutive line drawing 


<Program example> 


Draws broken lines as consecutive lines with the following attributes. 
e Drawing color: White 
e Line width: 5 pixels 
e Format: Floating point 
e Line pattern: Ipat 
e Draws line portion (x0,yO)=>(x1,y1)=>(x2,y2,) 


(x0, yO) 


(x2, y2) 
(x1, y1) 


Fig. Drawing Example 


/* When using driver function */ 
GdcGeoSetAttrMisc(GDC_GEO_VTX_Z,GDC_DISABLE); 
GdcColor(Ox7FFF); 

GdcSetLinePattern(Ipat); 

GdcSetAttrLine(GDC_DEPTH_TEST, GDC_DISABLE); 
GdcSetAttrLine(GDC_LINE_WIDTH, GDC_LINES_WIDTH_5); 
GdcGeoPrimType (GDC_POLYLINE); 
GdcGeoDrawVertex3Df( x0, y0); 

GdcGeoDrawVertex3Df( x1, y1); 

GdcGeoDrawVertex3Df( x2, y2); 

GdcGeo PrimEnd(); 


/* When using display list */ 


0xF1012040 
0x00000000 
0xF1010120 
0x00007FFF 
0xF1010123 
OxXXXXXXXX 
0xF1010109 
0x04080600 
0x21050000 
0x30000000 
OxXXXXXXXX 
OxXXXXXXXX 
0x30000000 
OxXXXXXXXX 
OxXXXXXXXX 
0x30000000 
OxXXXXXXXX 
OxXXXXXXXX 
0x23000000 


/* Type: Set Register, data count: 1, address: 8040 =>GMDRO */ 
/* Vertex Parameter Setting */ 
/* Type: Set Register, data count: 1, address: 480 =>FC */ 
/* Drawing color setting */ 
/* Type: Set Register, data count: 1, address: 48C =>BLP */ 
/* Broken line pattern setting */ 
/* Type: Set Register, data count: 1, address: 424 =>MDR1 */ 
/* Line drawing mode setting */ 
/*Type:G_Begin Command:Line_Strip*/ 
/*Type:G_Vertex */ 
/*float xO */ 
/*float yO */ 
/*Type:G_Vertex */ 
/*float x1 */ 
/*float y1 */ 
/*Type:G_Vertex */ 
/*float x2 */ 
/*float y2 */ 
/*Type:G_End */ 
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4.8.5 Triangle drawing 
Issues triangle drawing command with the various settings to perform MVP transformation, geometry 
and rendering attributes set. 
There are triangle, triangle fan and triangle strip drawing commands for triangle drawing. 
Triangle geometry and drawing attributes are set with the GMDRO and 1 registers and MDR2 register. 
e Performing tiling 
For tiling, Pattern data can be used only with the built-in TexRAM. 
Set to correspond to the TIS and TOA registers. 


e When texture mapping is used: 


Set the MDR3 and TXS registers, and set the TOA register when using the built-in TexRAM and the 
TBR register when placing the Tex pattern in the frame buffer. 


See 4.6.4 and 4.6.5 for details regarding how to transfer Tex (tile) patterns. 
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4.8.5.1 Multiple drawing of independent triangles 


<Program example> 
Draws triangles having drawing attributes with the following attributes. 


Triangle 1: 
e Format: Floating point 
e Vertex: (x0,y0,z0),(x1,y1,21),(x2,y2,z2) 
e Tiling: (Pointer ptnptrO (Size: 64 x 64) 
Triangle 2: 
e Format: Floating point 
e Vertex: (x3,y3,zZ3),(x4,y4,24),(x5,y5,z5) 
e Vertex color: (RO,GO,BO), (R1,G1,B1), (R2,G2,B2) 
e Texture mapping: (Modulate, Pointer: ptnptr1 (Size: 32 x 32) 
e Texture coordinates: (s0,t0,), ($1,t1), (s2,t2) 


(x0, yO, 20) (2, y2, 22) (x3, y3, 23) 


(x1, y1, 21) (x4, y4, 24) 


(x5, y5, 25) 
Fig. Drawing Example 

/* When using driver function */ 

Triangle 1 geometry attribute settings 
GdcGeoSetAttrMisc(GDC_GEO_VTX_COL,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_Z,GDC_ENABLE); Triangle 1 geometry 
GdcGeoSetAttrMisc(GDC_GEO_VTX_ST,GDC_ DISABLE); attribute settings 
GdcGeoSetAttrMisc(GDC_GEO_IN_FORMAT,GDC_GEO_FLOAT_INPUT); 
GdcSetAttrSurf(GDC_SHADE_MODE, GDC_SHADE_FLAT); 
GdcSetAttrSurf(GDC_DEPTH_TEST, GDC_ENABLE); 
GdcSetAttrSurf(GDC_DEPTH_FUNC, GDC_DEPTH_LEQUAL); 
GdcSetAttrSurf(GDC_BLEND_MODE, GDC_BLEND_COPY); 
GdcSetAttrSurf(GDC_ TEXTURE_SELECT, GDC_SELECT_TILE); 
GdcTextureLoadint(64*64,ptnptr0,0); 
GdcTextureMemoryMode(GDC_TEX_MEM_MODE_INT); 
GdcTextureDimension(0,64,64); 

GdcGeoPrimType (GDC_TRIANGLES); 

GdcGeoDrawVertex3Df( x0, y0, z0); 

GdcGeoDrawVertex3Df( x1, y1, 21); Triangle 1 drawing 
GdcGeoDrawVertex3Df( x2, y2, z2); 

GdcGeo PrimEnd(); 


GdcGeoSetAttrMisc(GDC_GEO_VTX_ST,GDC_DISABLE); 
GdcSetAttrSurf(GDC_SHADE_MODE, GDC_SHADE_SMOOTH); 
GdcSetAttrSurf(GDC_ TEXTURE_SELECT, GDC_SELECT_TEXTURE); 
GdcSetAttrTexture(GDC_ TEXTURE_PERSPECTIVE, GDC_ENABLE); 
GdcSetAttrTexture(GDC_ TEXTURE_BLEND, GDC_TEXTURE_MODULATE); 
GdcTextureLoadint(32*32,ptnptr1,0); 

GdcTextureDimension(0,32,32); 


Set part differing to triangle 1 
drawing attributes 
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GdcGeoPrimType (GDC_TRIANGLES); 
GdcGeoTexCoord2Df(s0,t0); 
GdcVertexColor3f(R0O,GO,BO); 
GdcGeoDrawVertex3Df( x3, y3, 23); 
GdcGeoTexCoord2Df(s1,t1); 


GdcVertexColor3f(R1,G1,B1); 


Triangle 2 drawing 


GdcGeoDrawVertex3Df( x4, y4, 24); 
GdcGeoTexCoord2Df(s2,t2); 
GdcVertexColor3f(R2,G2,B2); 
GdcGeoDrawVertex3Df( x5, y5, z5); 
GdcGeo PrimEnd(); 


/* When using display list */ 


0xF1012040 
0x00000005 
OxF101010A 
0x1000061C 
0xF101011B 
0x00000000 
0x11480800 
OxXXXXXXXX 


OxXXXXXXXX 
OxF101011A 
0x00400040 
0x21030000 
0x30000000 
OxXXXXXXXX 
OxXXXXXXXX 
OxXXXXXXXX 
0x30000000 
OxXXXXXXXX 
OxXXXXXXXX 
OxXXXXXXXX 
0x30000000 
OxXXXXXXXX 
OxXXXXXXXX 
OxXXXXXXXX 
0x23000000 
0xF1012040 
0x0000000f 
OxF101010A 
0x2000061D 
0xF101010B 
0x00010009 
0xF101011B 
0x00000000 
0x11480200 
OxXXXXXXXX 


OxXXXXXXXX 
0xF1010119 


/* Type: Set Register, data count: 1, address: 8040 =>GMDRO */ 
/* Vertex parameter setting */ 

/* Type: Set Register, data count: 1, address: 428 =>MDR2 */ 
/* Triangle drawing attributes setting */ 

/* Type: Set Register, data count: 1, address: 468 =>TOA */ 
/* Built-in TexRAM address setting */ 

/* Type: Load TextureP, Cmd: LoadTexture data count: 0x800 */ 
/* Tex pattern from here */ 


64*64/2 


/* Tex pattern to here */ 

/* Type: Set Register, data count: 1, address: 468 =>TIS */ 
/* Tile size setting */ 

/*Type:G_Begin Command:Triangles*/ 

/*Type:G_Vertex */ 
/*float xO */ 
/*float yO */ 
/*float z0 */ 

/*Type:G_Vertex */ 
/*float x1 */ 
/*float y1 */ 
/*float z1 */ 

/*Type:G_Vertex */ 
/*float x2 */ 
/*float y2 */ 
/*float z2 */ 

/*Type:G_End */ 

/* Type: Set Register, data count: 1, address: 8040 =>GMDRO */ 
/* Vertex parameter setting */ 

/* Type: Set Register, data count: 1, address: 428 =>MDR2 */ 
/* Triangle drawing attributes setting */ 

/* Type: Set Register, data count: 1, address: 42C =>MDR3 */ 
/* Texture mapping drawing attributes setting */ 

/* Type: Set Register, data count: 1, address: 468 =>TOA */ 
/* Built-in TexRAM address setting */ 

/* Type: Load TextureP, Cmd: LoadTexture data count: 0x200 */ 
/* Tex pattern from here */ 


Triangle 1 drawing 


32*32/2 


/* Tex pattern to here */ 
/* Type: Set Register, data count: 1, address: 464 =>TXS */ 
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0x00200020 /* Texture size setting */ 
0x21030000 /*Type:G_Begin Command:Triangles*/ 
0x30000000 /*Type:G_Vertex */ 
OxXXXXXXXX /*float x3 */ 
OxXXXXXXXX /*float y3 */ 
OxXXXXXXXX /*float z3 */ 
OxXXXXXXXX /*float RO */ 
OxXXXXXXXX /*float GO */ 
OxXXXXXXXX /*float BO */ 
OxXXXXXXXX /*float SO */ 
OxXXXXXXXX /*float TO */ 
0x30000000 /*Type:G_Vertex */ 
OxXXXXXXXX /*float x4 */ 
OxXXXXXXXX /*float y4 */ 
OxXXXXXXXX /*float 24 */ 
OxXXXXXXXX /*float R1 */ 
OxXXXXXXXX /*float G1 */ 
OxXXXXXXXX /*float B1 */ 
OxXXXXXXXX /*float S1 */ 
OxXXXXXXXX /*float T1 */ 
0x30000000 /*Type:G_Vertex */ 
OxXXXXXXXX /*float x5 */ 
OxXXXXXXXX /*float y5 */ 
OxXXXXXXXX /*float z5 */ 
OxXXXXXXXX /*float R2 */ 
OxXXXXXXXX /*float G2 */ 
OxXXXXXXXX /*float B2 */ 
OxXXXXXXXX /*float S2 */ 
OxXXXXXXXX /*float T2 */ 
0x23000000 /*Type:G_End */ 
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4.8.5.2 Triangle strip drawing 
This draws by connecting the vertices (n-2), (n-1) and (n) specified by the triangle fan. 


Drawing is executed by transferring only the vertex coordinates at any time so the display list is greatly 
reduced. 


<Program example> 
e Format: Floating point 
e Vertex: (x0,y0,20),(x1,y1,21),(x2,y2,22), (x3,y3,z3) 
e a Blend 


(x1, yl , z1) (x3, y3, Z3) 


(x0, yO, z0) (x2, y2, 22) 


Fig. Drawing Example 


/* When using driver function */ 
GdcGeoSetAttrMisc(GDC_GEO_VTX_COL,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_Z,GDC_ENABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_ST,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_IN_FORMAT,GDC_GEO_FLOAT_INPUT); 
GdcSetAttrSurf(GDC_SHADE_MODE, GDC_SHADE_FLAT); 
GdcSetAttrSurf(GDC_DEPTH_TEST, GDC_ENABLE); 
GdcSetAttrSurf(GDC_DEPTH_FUNC, GDC_DEPTH_LEQUAL); 
GdcSetAttrSurf(GDC_BLEND_MODE, GDC_BLEND_ALPHA); 
GdcSetAttrSurf(GDC_ TEXTURE_SELECT, GDC_SELECT_PLAIN); 
GdcSetAlpha(0x80); 

GdcGeoPrimType (GDC_TRIANGLE_STRIP); 

GdcGeoDrawVertex3Df( x0, yO, z0); 

GdcGeoDrawVertex3Df( x1, y1, 21); 
GdcGeoDrawVertex3Df( x2, y2, z2); 
GdcGeoDrawVertex3Df( x2, y2, z2) 


/* When using display list */ 


0xF1012040 /* Type: Set Register, data count: 1, address: 8040 =>GMDRO */ 
0x00000004 /* Peak Parameter Setting */ 

0xF101010A /* Type: Set Register, data count: 1, address: 428 =>MDR2 */ 
0x0000069C /* Triangle Draw Attributes Setting */ 

0OxF1010122 /* Type: Set Register, data count: 1, address: 488 =>ALF */ 
0x00000080 /* Blend Coefficient Setting */ 

0x21070000 /*Type:G_Begin Command:Triangle_Strip*/ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float xO */ 

OxXXXXXXXX /*float yO */ 

OxXXXXXXXX /*float z0 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x1 */ 

OxXXXXXXXX /*float y1 */ 
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OxXXXXXXXX 
0x30000000 
OxXXXXXXXX 
OxXXXXXXXX 
OxXXXXXXXX 
0x23000000 


/*float z1 */ 
/*Type:G_Vertex */ 
/*float x2 */ 
/*float y2 */ 
/*float z2 */ 
/*Type:G_End */ 
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4.8.5.3 Triangle fan drawing 
This draws by connecting the vertices (n-1) and (n) centering on the vertex 0 specified by the triangle fan. 


Drawing is executed by transferring only the peak coordinates at any time so the display list is greatly 
reduced. 


<Program example> 
e Format: Floating point 
e Vertex: (x0,y0),(x1,y1),(x2,y2), (x3,y3) 
e Logic Operation: OR 


(x0, yO, 20) (x3, y3, 23) 


1,y1, z1 
eee (x2, y2, 22) 


Fig. Drawing Example 


/* When using driver function */ 
GdcGeoSetAttrMisc(GDC_GEO_VTX_COL,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_Z,GDC_ENABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_ST,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_IN_FORMAT,GDC_GEO_FLOAT_INPUT); 
GdcSetAttrSurf(GDC_SHADE_MODE, GDC_SHADE_FLAT); 
GdcSetAttrSurf(GDC_DEPTH_TEST, GDC_ENABLE); 
GdcSetAttrSurf(GDC_DEPTH_FUNC, GDC_DEPTH_LEQUAL); 
GdcSetAttrSurf(GDC_BLEND_MODE, GDC_BLEND_ROP); 
GdcSetAttrSurf(GDC_ TEXTURE_SELECT, GDC_SELECT_PLAIN); 
GdcSetRop(GDC _ROP_OR); 

GdcGeoPrimType (GDC_TRIANGLE_FAN); 

GdcGeoDrawVertex3Df( x0, yO, z0); 

GdcGeoDrawVertex3Df( x1, y1, 21); 
GdcGeoDrawVertex3Df( x2, y2, z2); 
GdcGeoDrawVertex3Df( x2, y2, z2) 
GdcGeo PrimEnd(); 
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/* When using display list */ 


0xF1012040 /* Type: Set Register, data count: 1, address: 8040 =>GMDRO */ 
0x00000004 /* Vertex parameter setting */ 

0OxF101010A /* Type: Set Register, data count: 1, address: 428 =>MDR2 */ 
0x00000E1C /* Triangle drawing attributes setting */ 

0x21080000 /*Type:G_Begin Command:Triangle_Fan*/ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float xO */ 

OxXXXXXXXX /*float yO */ 

OxXXXXXXXX float z0 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x1 */ 

OxXXXXXXXX /*float y1 */ 

OxXXXXXXXX /*float z1 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x2 */ 

OxXXXXXXXX /*float y2 */ 

OxXXXXXXXX /*float z2 */ 

0x23000000 /*Type:G_End */ 
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4.8.6 Polygon (Any Polygon) drawing 


Issues triangle drawing command with the various settings to perform MVP transformation, geometry and 
rendering attributes set. 


Polygon drawing is a function for drawing any closed polygons including concave shapes comprising 
vertices. (However, this does not support polygons having intersected sides.) 


The polygon drawing flag buffer requires “drawing frame (1 pixel = 1 bit) + X resolution (1 pixel = 1 bit) x 
2” bits of memory on the graphics memory as the work area for drawing. It is necessary to set the buffer 
address (PFBR register) to leave that amount free for X resolution. Refer to the product specifications for 
details. 


Note that it is not possible to delete hidden plane erasing, texture mapping or gouraud shading that use 
the Z buffer. 


<Program example> 
e Format: Floating point 
e Vertex: (x0,yO) to (x7,y7) 
e a Blend 


(x3, y3) 


Fig. Drawing Example 


/* When using driver function */ 
GdcGeoSetAttrMisc(GDC_GEO_VTX_COL,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_Z,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_ST,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_IN_FORMAT,GDC_GEO_FLOAT_INPUT); 
GdcSetAttrSurf(GDC_SHADE_MODE, GDC_SHADE_FLAT); 
GdcSetAttrSurf(GDC_DEPTH_TEST, GDC_DISABLE); 
GdcSetAttrSurf(GDC_BLEND_MODE, GDC_BLEND_ALPHA); 
GdcSetAttrSurf(GDC_ TEXTURE_SELECT, GDC_SELECT_PLAIN); 
GdcSetAlpha(0x80); 

GdcGeoPrimType (GDC_POLYGON); 

GdcGeoDrawVertex2Df( x0, y0); 

GdcGeoDrawVertex2Df( x1, y1) 

GdcGeoDrawVertex2Df( x2, y2) 

GdcGeoDrawVertex2Df( x2, y2) 

GdcGeoDrawVertex2Df( x3, y3) 

GdcGeoDrawVertex2Df( x4, y4); 
) 
) 
) 


GdcGeoDrawVertex2Df( x5, y5 
GdcGeoDrawVertex2Df( x6, y6 
GdcGeoDrawVertex2Df( x7, y7 
GdcGeo PrimEnd(); 


Se eS ee SS ee 
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/* When using display list */ 


0xF1012040 /* Type: Set Register, data count: 1, address: 8040 =>GMDRO */ 
0x00000000 /* Vertex parameter setting */ 
0xF101010A /* Type: Set Register, data count: 1, address: 428 =>MDR2 */ 
0x00000680 /* Triangle drawing attributes setting */ 
OxF1010122 /* Type: Set Register, data count: 1, address: 488 =>ALF */ 
0x00000080 /* a coefficient setting */ 

0x21020000 /*Type:G_Begin Command:Polygon*/ 
0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float xO */ 

OxXXXXXXXX /*float yO */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x1 */ 

OxXXXXXXXX /*float y1 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x2 */ 

OxXXXXXXXX /*float y2 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x3 */ 

OxXXXXXXXX /*float y3 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x4 */ 

OxXXXXXXXX /*float y4 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x5 */ 

OxXXXXXXXX /*float y5 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x6 */ 

OxXXXXXXXX /*float y6 */ 

0x30000000 /*Type:G_Vertex */ 

OxXXXXXXXX /*float x7 */ 

OxXXXXXXXX /*float y7 */ 

0x23000000 /*Type:G_End */ 


66 


me) 
FUJITSU 


4.9 Drawing Using the Rendering Commands 


It is possible to directly specify the drawing device coordinates to draw as the Cremson upper compatible 
LSI. 


It is necessary to set as described in Sections 4.8.2.2 and 4.7 for proper handling of the various drawing 
attributes and Z buffer. 


4.9.1 Point drawing 


<Drawing> 
e¢ Point color: White 
e Point drawing coordinates: (X, Y) = (100, 150) 
e Figure drawing attributes: Alpha blending (a coefficient 0x80) 


| ge eee 

Point drawing program 
seco eie stot se loo 2 es ee ee pec eetee sss ae ee ee eee tos oo fee Son esos ease sets 2 es ee! a 
[*--2------------------ Driver function use example ------------------------------------------ */ 
GdcSetAttrLine (GDC_BLEND_ MODE, GDC_BLEND_ALPHA ); /* Blend mode setting */ 
GdcSetAlpha ( 0x80 ); /* Alpha blend coefficient setting */ 
GdcPrimType (GDC_POINTS ); /* Drawing primitive type setting */ 
GdcColor ( Ox7FFF ); /* 16 bit point color setting */ 
GdcDrawVertex2D ( 0x00640000, 0x00960000 ); /* Vertex coordinates setting */ 
GdcPrimEnd ( ); /* Point drawing end */ 
[*---------------------- Display list example ------------------------------------------------------ */ 
F1010109 /* Type: Set Register, data count: 1, address: 109 =>424 */ 
00000680 /* MDR1 register blend mode setting */ 
F1010122 /* Type: Set Register, data count: 1, address: 122 =>488 */ 
00000080 /* ALF register alpha blending coefficient setting */ 
F1010120 /* Type: Set Register, data count: 1, address: 120 =>480 */ 
00007FFF /* FC register foreground color setting */ 
00000000 /*Type: DrawPixel, Command: Pixel */ 
00648000 /* X coordinates setting */ 
00968000 /* Y coordinates setting */ 
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4.9.2 Line drawing 


<Drawing> 
e Linecolor: White 
e Line drawing coordinates: ( X, Y, Z ) = ( 20, 16, 10) , ( 150, 250, 160) 
e Z value comparison method: Draw if Z value is smaller than Z buffer. 


e Figure drawing attributes: Broken line, line width 15 pixels, anti-alias processing 

Pd atc ee eh ee et ae cele ey sett eee el etal ath Seber aloe 
3D Line drawing program example 

So Seee Sots eas See ee ee otbe oat ees otee Se see oe oe a ts eee eee he ea oe a ee tele o 
[* --2------------------ Driver function use example ------------------------------------------- */ 
GdcSetAttrLine (GDC_DEPTH_TEST, GDC_ENABLE ); /* Z value comparison mode setting */ 
GdcSetAttrLine (GDC_DEPTH_FUNC, GDC_DEPTH_LESS ); /* Z comparison equation setting */ 
GdcSetAttrLine (GDC_DEPTH_WRITE_MASK, GDC_DISABLE );_ /* Write Z value to Z buffer */ 
GdcSetAttrLine (GDC_BLEND_MODE, GDC_BLEND_COPY ); /* Set drawing blend mode to logic operation */ 
GdcSetAttrLine (GDC_BROKEN_LINE, GDC_ENABLE ); /* Draw broken line */ 
GdcSetAttrLine (GDC_LINE_WIDTH, GDC_LINE_WIDTH_15 ); /* Set line width to 15 pixels */ 
GdcSetAttrLine (GDC_ANTI_ALIAS, GDC_ENABLE ); /* Anti-alias process setting */ 
GdcSetLinePattern ( OxFFFFOOOO ); /* Broken line pattern setting */ 
GdcPrimType ( GDC_LINES ); /* Drawing primitive type setting */ 
GdcColor ( GDC_RED); /* 16 bit line color setting */ 
GdcDrawVertex3D ( 0x000A0000, 0x000A0000, Ox000A ); /* Vertex coordinates setting */ 
GdcDrawVertex3D ( 0x00F60000, OxO0FA0000, Ox00A0 ); /* Vertex coordinates setting */ 
[*---------------------- Display list example -------------------------------------------------------- */ 
F1010109 /* Type: Set Register, data count: 1, address: 109 =>424 */ 
0E080014 /* MDR1 register Line drawing mode setting */ 
F1010123 /* Type: Set Register, data count: 1, address: 123 =>48C */ 
FFFFOO0O /* BLP register Broken line pattern setting */ 
F1010120 /* Type: Set Register, data count: 1, address: 120 =>480 */ 
00007C00 /* FC register drawing color setting */ 
F1020055 /* Type: Set Register, data count: 1, address: 55 =>154 */ 
00050000 /*LZs_ Line position drawing starting point Z coordinates setting */ Z component settings 
00005000/* LZde Z incline value setting */ 
022D0000 /*Type: DrawLine,Cmd: AntiYvectorBlpClear*/ 
0OFO0000 /* LPN’ Principal axis direction pixel count */ 
00030000 /* LXs_ Line position drawing starting point X coordinates setting */ 
OOOOFBBB /*Lxde X incline value setting */ Line drawing 
000A0000 /* LYs_ Line position drawing starting point Y coordinates setting */ 
00010000 /* LYde_Y incline value setting */ 
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4.9.3 Triangle drawing 


< Drawing > 
e §6Triangle drawing coordinates: (X, Y, Z ) = (100, 100, 255) , ( 150, 250, 0) , ( 100, 200, 255 ) 
e Figure drawing attribute: Texture mapping, GURO shading 
e Texture attributes: Perspective collect, bi-linear sampling, texture wrap repeat, texture blend module 
e Texture pattern: Pattern stored in COL16 type pointer movieO1 
e Texture size: 128 x 128 pixels 
e Texture memory: Loaded to the graphics memory address 0x500000. 
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Triangle drawing program using texture mapping 
(With GURO shading) 


wee el eS a ee */ 
[eSnarocceec agen Driver function use example ------------------------------------0=-"--- Mh 

GdcSetAttrSurf (GDC_SHADE_MODE, GDC_SHADE_SMOOTH ); /* Shading mode setting 

GdcSetAttrSurf (GDC_DEPTH_TEST, GDC_ENABLE ); /* Z value comparison mode setting */ 
GdcSetAttrSurf (GDC_DEPTH_FUNC, GDC_DEPTH_LESS ); /* Z value comparison equation setting */ 
GdcSetAttrSurf (GDC_DEPTH_WRITE_MASK, GDC_DISABLE ); /* Z value write enable mode setting */ 
GdcSetAttrSurf (GDC_BLEND_MODE, GDC_BLEND_COPY ); /* Blend mode setting */ 


GdcSetAttrSurf (GDC_TEXTURE_SELECT, GDC_SELECT_TEXTURE ); /* Texture mode setting */ 
GdcSetAttrTexture (GDC_TEXTURE_PERSPECTIVE, GDC_ENABLE ); 

/* Texture coordinates correct mode setting */ 
GdcSetAttrTexture (GDC_TEXTURE_FILTER, GDC_TEXTURE_BILINEAR ); 

/* Texture coordinates correct mode setting */ 
GdcSetAttrTexture (GDC_TEXTURE_WRAP_S, GDC_TEXTURE_REPEAT ); 

/* Texture S coordinates wrap method setting */ 
GdcSetAttrTexture (GDC_TEXTURE_WRAP_T, GDC_TEXTURE_REPEAT ); 

/* Texture T coordinates wrap method setting */ 
GdcSetAttrTexture (GDC_TEXTURE_BLEND, GDC_TEXTURE_MODULATE ); 

/* Texture color and polygon color blend setting */ 
GdcTextureLoadExt ( (128*128), movie01, 0x500000 ); /* Load texture pattern to graphics memory */ 
GdcTextureMemoryMode ( GDC_TEX_MEM_MODE_EXT ); 

/* Set texture pattern reference destination memory to internal or external */ 

GdcTextureDimension ( 0x500000, 128, 128); /* Texture size and address to reference texture setting */ 


GdcPrimType (GDC_TRIANGLES ); /* Drawing primitive setting */ 
GdcColor ( GDC_GRAY ); /* Vertex color setting */ 
GdcTexCoord3DNf ( 0.0f, 0.0f, 0.5f ); /* Vertex texture coordinates setting */ 
GdcDrawVertex3D ( 0x00640000, 0x00640000, OxFF ); /* Vertex coordinates setting */ 
GdcTexCoord3DNf ( 0.0f, 1.0f, 0.5f ); /* Vertex texture coordinates setting */ 
GdcDrawVertex3D ( 0x00640000, 0x00C80000, OxFF); /* Vertex coordinates setting */ 
GdcColor (GDC_YELLOW ); /* Vertex color setting */ 
GdcTexCoord3DNf ( 1.0f, 0.5f, 1.0f ); /* Vertex texture coordinates setting */ 
GdcDrawVertex3D ( 0xOOFA0000, 0x00960000, 0x00); /* Vertex coordinates setting */ 
GdcPrimEnd ( ); /* Drawing primitive end */ 
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[Masecesecsecstaes Display list example ------------------ */ 
F101010A /* Type: Set Register, data count: 1, address: 10A =>428 */ 
20000615 /* MDR2 register Window drawing mode setting */ 
F101010B /* Type: Set Register, data count: 1, address: 10B =>42C */ 
00010528 /* MDR@ register Texture mapping process mode setting */ 
F1010113 /* Type: Set Register, data count: 1, address: 113 =>44C */ 
00500000 /* TBR Register Texture memory base setting */ 
F101010C (Note) /* Type: Set Register, data count: 1, address: 10 =>430 */ 
00000700 /* MDR4 register BLT mode setting */ 
F1010110 /* Type: Set Register, data count: 1, address: 110 =>440 */ 
00500000 /* FBR register Drawing frame base address setting */ 
F1010111 /* Type: Set Register, data count: 1, address: 111 =>440 */ 
00000080 /* XRES Register Drawing window X axis direction resolution setting */ 
0B422002 /* Type: Draw Bit map P, Cmd: BltDram, data count: 8194 */ 
00000000 /* RYs, RXs, Drawing starting point coordinates setting of Y, X */ 
00800080 /* RsizeY, RsizeX Y, X direction drawing size setting */ 
3E533E53 /* Texture pattern */ 
8192 texture patterns 
3E533E53 /* Texture pattern */ 
F101010C (Note) /* Type: Set Register, set data count: 1, address: 10C =>430 */ 
00000000 /* MDR4 register BLT mode setting */ 
F1010110 /* Type: Set Register, data count: 1, address: 110 =>440 */ 
00000000 /* FBR register Drawing frame base address setting */ ret 
F1010111 /* Type: Set Register, data count: 1, address: 111 =>440 */ Mecovely Gf original 
00000280 /* XRES Register Drawing window X axis direction resolution setting */ selina Valle 
F1010120 /* Type: Set Register, data count: 1, address: 120 =>480 */ 
00004210 /* FC register Foreground color for drawing setting */ 
F1010119 /* Type: Set Register, data count: 1, address: 119 =>464 */ 
00800080 /* TXS register Texture size setting */ 
F1030020 /* Type: Set Register, data count: 3, address: 20 =>80 */ 
007F8000 /*Zs_ Long edge starting Z coordinates relating to Ys setting */ Z component 
FFFF2667 /* dZdx Z add value of the X axis direction setting */ settings 
00000000 /* dZdx Z add value of the long edge direction */ 
F1090010 /* Type: Set Register, data count: 9, address: 10 =>40 */ 
00800000 /* Rs Long edge starting color value R relating to Ys setting */ 
0000CCCC /* dRdx R add value of the X axis direction setting */ 
00000000 /* dRdx R add value of the long edge direction setting */ 
00800000 /* Gs___Long edge starting color value G relating to Ys setting */ Color component 
0000CCCC /* dGdx G add value of the X axis direction setting */ setting 
00000000 /* dGdy Gadd value of the long edge direction setting */ 
00800000 /* Bs Long edge starting color value B relating to Ys setting */ 
FFFF258C /* dBdx B add value of the X axis direction setting */ 
00000000 /* dBdy B add value of the long edge direction setting */ 


71 


MB86292 ORCHID APPLICATION NOTE 


F1090030 
00000000 
0000DA74 
00000000 
00000000 
0000369D 
0000A3D7 
00800000 
0000DA74 
00000000 
05600000 
00640000 
00640000 
00000000 
OO63FFFF 
00030000 
OOF9FFFE 
FFFDO001 
00320000 
00320000 


/* Type: Set Register, data count: 9, address: 30 =>C0 */ 
/* Ss_ Long edge starting S texture coordinates relating to Ys setting */ 
/* dSdx_ S add value of the X axis direction setting */ 
/* dSdx_ S add value of the long edge direction */ 
/* Ts Long edge starting T texture coordinates relating to Ys setting */ Texture component 
/* dTdx_ T add value of the X axis direction setting */ setting 
/* dTdy_ T add value of the long edge direction */ 
/* Qs_ Long edge starting depth correction value setting relating to Ys */ 
/* dQdx W add value of the X axis direction setting */ 
/* dQdy Qadd value of the long edge direction */ 

/* Type: DrawTrap,Cmd: TrapRight*/ 
/*Ys_ Long edge starting Y coordinates setting */ 
/* Xs_ Long edge starting X coordinates relating t Ys setting */ 
/* DXdy X add value of the long edge direction */ 
/* XUs_ Upper edge starting X coordinates setting */ Draw triangle 
/* DXUdy X add value of the upper edge direction */ 
/* XLs_ Lower edge starting X coordinates setting */ 
/* DXLdy X add value of the lower edge direction */ 
/* USN. Sets upper triangle span count */ 
/* LSN_ Sets lower triangle span count */ 
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5. CREATING APPLICATION PROGRAMS 


This section describes program example that makes the best use of Orchid’s performance and functions. 


Review this section when creating applications. 


5.1 Executing Only the Setup Process Using Orchid 


The following example shows a program example that executes the setup with Orchid by passing the 
drawing device coordinates directly to Orchid. 


Set the parameters as shown below. Set the rendering attributes to their appropriate values. 


Note that view clip settings are off in the example below, but if the object coordinates applied to Orchid 
are outside of the draw frame excessively, set the X, Y and Z view clip frame properly. See Sections 4.4 
and 4.6.2.4. 


¢ Queue: Increment Queue 
1.0f O.0f O.0f  0.Of 
0.0f 1.0f O.0f  0.0f 
0.0f oof 1.0f  0.0f 
0.0f gof 0.0f  1.0f 


e View Port: Offset is 0, Scale is 1 magnification. 


e View Clip: Off 
min = -3.40282347e+38(Oxff7fffff) (Single precision Float minimum value) 
max = 3.40282347e+38(0x7f7fffff) (Single precision Float maximum value) 
wmin = 1.1754944e-38(0x00800000) (Single precision Float positive minimum value) 


¢ GMDRO register: FrustumBit (Bit0) = 0 (When using the driver, it is automatically set by setting the 
increment queue. 
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<Program example> 


e Draws triangles (100.0f,100.0f,100.0f), (100.0f,200.0f,100.0f), (200.0f,200.0f,100.0f) with the color 
parameters (1.0f, 0, 0), (0, 1.0f, 0), (0, 0, 1.0f). 


/* When using driver function */ 

float mat[] = {1,0,0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1}; // increment 
float min = -3.40282347e+38; float max = 3.40282347e+38; float wmin = 1.1754944e-38; 
GdcGeoLoadMatrixf(mat); 

GdcGeoNdcDcViewportCoeff( 1.0f, 0, 1.0f, 0); 
GdcGeoNdcDcDepthCoeff( 1.0f, 0); 
GdcGeoViewVolumeXYClip( min, max, min, max); 
GdcGeoViewVolumeZClip( min, max); 
GdcGeoViewVolumeWminClip( wmin); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_Z,GDC_ENABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_COL,GDC_ENABLE); 
GdcSetAttrSurf(GDC_DEPTH_TEST, GDC_ENABLE); 
GdcSetAttrSurf(GDC_DEPTH_FUNC, GDC_DEPTH_LEQUAL); 
GdcSetAttrSurf(GDC_SHADE_MODE, GDC_SHADE_SMOOTH); 
GdcGeoPrimType (GDC_TRIANGLES); 

GdcVertexColor3f(1.0f, 0.0f, 0.0f); 

GdcGeoDrawVertex3Df( 100.0f, 100.0f, 100.0f); 
GdcVertexColor3f(0.0f, 1.0f, 0.0f); 

GdcGeoDrawVertex3Df( 100.0f, 200.0f, 100.0f); 
GdcVertexColor3f(0.0f, 0.0f, 1.0f); 

GdcGeoDrawVertex3Df( 200.0f, 200.0f, 100.0f); 

GdcGeo PrimEnd 


/* When using display list */ 


0x43000000 /* Type:G_LoadMatrix */ 
0x3F800000 /*Matrix_a0 */ 
0x00000000 /*Matrix_a1 */ 
0x00000000 /*Matrix_a2 */ 
0x00000000 /*Matrix_a3 */ 
0x00000000 /*Matrix_b0 */ 
0x3F800000 /*Matrix_b1 */ 
0x00000000 /*Matrix_b2 */ 
0x00000000 /*Matrix_b3 */ Queue setting 
0x00000000 /*Matrix_cO */ 
0x00000000 /*Matrix_c1 */ 
0x3F800000 /*Matrix_c2 */ 
0x00000000 /*Matrix_c3 */ 
0x00000000 /*Matrix_dO */ 
0x00000000 /*Matrix_d1 */ 
0x00000000 /*Matrix_d2 */ 
0x3F800000 /*Matrix_d3 */ 
0x41000000 /* Type:G_Viewport */ 
0x3F800000 /*X_Scaling */ 
0x00000000 /*X_Offset */ 
0x3F800000 /*Y_Scaling */ 
0x00000000 /*Y_Offset */ 
0x42000000 /* Type:G_DepthRange */ 
0x3F800000 /*Z_Scaling */ 
0x00000000 /*Z_Offset */ 
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0x44000000 
OxFF7FFFFF 
Ox7F7FFFFF 
OxFF7FFFFF 
Ox7F7FFFFF 
0x45000000 
OxFF7FFFFF 
Ox7F7FFFFF 
0x46000000 
0x00800000 
0xF1012010 
0x00000006 
0xF101010A 
0x0000061D 
0x21030000 
0x30000000 
0x42C80000 
0x42C80000 
0x42C80000 
0x3F800000 
0x00000000 
0x00000000 
0x30000000 
0x42C80000 
0x43480000 
0x42C80000 
0x00000000 
0x3F800000 
0x00000000 
0x30000000 
0x43480000 
0x43480000 
0x42C80000 
0x00000000 
0x00000000 
0x3F800000 
0x23000000 


/* Type:G_ViewVolumeXYClip */ 
/*XMIN */ 
/*XMAX */ 
/*YMIN */ 
/*YMAX */ 

/* Type:G_ViewVolumeZClip */ 
/*ZMIN */ 
/*ZMAX */ 

/* Type:G_ViewVolumeWClip */ 
/*WMIN */ 


/* Type: Set Register, data count: 1, address: 8040 =>GMDRO */ 


/* Peak Parameter Setting */ 


/* Type: Set Register, data count: 1, address: 428 =>MDR2 */ 
/* Triangle rendering mode setting */ 


/*Type:G_Begin Command:Triangles*/ 


/*Type:G_Vertex */ 
/*float xO */ 
/*float yO */ 
/*float 20 */ 
/*float rO */ 
/*float gO */ 
/*float b0 */ 
/*Type:G_Vertex */ 
/*float x1 */ 
/*float y1 */ 
/*float z1 */ 
/*float r1 */ 
/*float g1 */ 
/*float b1 */ 
/*Type:G_Vertex */ 
/*float x2 */ 
/*float y2 */ 
/*float z2 */ 
/*float r2 */ 
/*float g2 */ 
/*float b2 */ 
/*Type:G_End */ 
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5.2 Executing 2D Transformation Using Orchid 


The following shows a program that transforms from object coordinates to the 2D coordinates to execute 
drawing. 


When the GMDRO register Frustum mode bit is “O” and the Z data enable bit is “0”, it ignores Z and 
calculates as the 3 x 2 queue but division using Wcc is not performed. 


The following shows a description of the method of calculation. Refer to Sections 7.1.2 and 7.1.3 in the 
specifications for Orchid for details regarding 3D conversion calculations. 


To transform 2D coordinates with Orchid, set the queue to load to Orchid as the following. 


Calculations using Orchid: Glistieteildadte Orchid 


Xcc MAO MAt1 0 MA2 Xoc 
Ycc MBO MB1 0 MB2 Yoc 
O Wr > EG. Ao Ok. «6 0 
1 0 0 0 1 1 


Xcc = MAO*Xoc + MA1*Yoc + MCO 
Ycc = MBO*Xoc + MB1*Yoc + MC1 


<Program Example> 


Draws the triangle with object coordinates (-1.0f, 1.0f), (-1.0f, -1.0f) and (1.0f, -1.0f) by view port center 
(320, 240), view port scale (50, 50), view clop off and moving X by 3 with transformation queue. 
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/* When using driver function */ 


float mat[] = {1,03.0,0, 0,1,0,0, 0,0,1,0, 0,0,0,1}; // increment 


float min = -3.40282347e+38; float max = 3.40282347e+38; float wmin = 1.17549435e-38; 


GdcGeoLoadMatrixf(mat); 

GdcGeoNdcDcViewportCoeff( 50.0f, 320.0f, 50.0f, 240.0f); 
GdcGeoViewVolumeXYClip( min, max, min, max); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_Z,GDC_DISABLE); 
GdcSetAttrSurf(GDC_DEPTH_TEST, GDC_DISABLE); 
GdcGeoPrimType (GDC_TRIANGLES); 
GdcGeoDrawVertex2Df( -1.0f, 1.0f); 
GdcGeoDrawVertex2Df( -1.0f, -1.0f); 
GdcGeoDrawVertex2Df( 1.0f, -1.0f); 

GdcGeo PrimEnd(); 


0x43000000 
0x3F800000 
0x00000000 
0x00000000 
0x40400000 
0x00000000 
0x3F800000 
0x00000000 
0x00000000 
0x00000000 
0x00000000 
0x3F800000 
0x00000000 
0x00000000 
0x00000000 
0x00000000 
0x3F800000 
0x41000000 
0x42480000 
0x43A00000 
0x42480000 
0x43700000 
0x44000000 
OxFF7FFFFF 
Ox7F7FFFFF 
OxFF7FFFFF 
Ox7F7FFFFF 
0xF1012040 
0x00000000 
OxF101010A 
0x00000600 
0x21030000 
0x30000000 
0xBF800000 
0x3F800000 
0x30000000 
0xBF800000 
0xBF800000 


/* When using display list */ 


/* Type:G_LoadMatrix */ 
/*Matrix_a0 */ 
/*Matrix_a1 */ 
/*Matrix_a2 */ 
/*Matrix_a3 */ 
/*Matrix_b0 */ 
/*Matrix_b1 */ 
/*Matrix_b2 */ 
/*Matrix_b3 */ 
/*Matrix_cO */ 
/*Matrix_c1 */ 
/*Matrix_c2 */ 
/*Matrix_c3 */ 
/*Matrix_dO */ 
/*Matrix_d1 */ 
/*Matrix_d2 */ 
/*Matrix_d3 */ 

/* Type:G_Viewport */ 
/*X_Scaling */ 
/*X_Offset */ 
/*Y_Scaling */ 
/*Y_Offset */ 

/* Type:G_ViewVolumeXYClip */ 
/*XMIN */ 

/*XMAX */ 
/*YMIN */ 
[*YMAX */ 

/* Type: Set Register, data count: 1, address: 8040 =>GMDRO */ 
/* Vertex parameter setting */ 

/* Type: Set Register, data count: 1, address: 428 =>MDR2 */ 
/* Triangle rendering mode setting */ 

/*Type:G_Begin Command:Triangles*/ 

/*Type:G_Vertex */ 

/*float xO */ 
/*float yO */ 
/*Type:G_Vertex */ 
/*float x1 */ 
/*float y1 */ 


Queue setting 


77 


me) 
FUJITSU 


MB86292 ORCHID APPLICATION NOTE 


0x30000000 /*Type:G_Vertex */ 
0x3F800000 /*float x2 */ 
OxBF800000 /*float y2 */ 
0x23000000 /*Type:G_End */ 
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5.3 Drawing a Bird’s-eyes View Image Using Orchid 


The following shows an example in which the queue operation is performed by 4 x 4 and drawing is 
executed without Z buffer. 


This method is effective to incline a 2D map and draw a bird’s-eye view of the map. 


When the GMDRO register Frustum mode bit is “1” and the Z data enable bit is “0”, the geometry engine 
calculates the coordinates transformation of the 4 x 4 queue as Z = 0; with the rendering engine, it issues 
a command with no Z buffer to draw. 


<Program example> 


e Transforms queues and draws by setting object coordinates (-1.0f, 5.0f), (-1.0f, -5.0f), (1.0f, 5.0f) and 
(1.0f, -5.0f) with triangle strip to view port center (320, 240), view port scale (200.0f, 200.0f), view clip 
xmin = -2.0f, xmax = 2.0f, ymin = -1.25f, ymax = 1.25f, zmin = -1.0f, zmax = 1.0f, and wmin = 
0.000000001f. 


Video image of a 90° viewpoint Video image of a 10° viewpoint 
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/* When using driver function */ 
/* Matrix of incline of 10° */ 
float mat1O[] = { -1.0f, 0.f, 0.f, 0.f, 0.f,-0.173648f,0.f, 0.984808f, 
0.f, -0.984808f, 0.f, -0.173648f, 0.f, 0.f, 0.1f, 5.0f; 
/* Matrix of incline of 90° */ 
float mat90[] = { -1.0f, 0.f, 0.f, O.f, 0.f,-1.0f,0.f, 0. f, 

O.f, 0.f, 0.f, -1.0f, 0.f, O.f, 0.1f, 5.0f}; 
GdcGeoSetAttrMisc(GDC_GEO_IN_FORMAT, GDC_GEO_FLOAT_INPUT); 
GdcGeoSetAttrSurf(GDC_GEO_FACE_CULL, GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_Z, GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_COL, GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_ST, GDC_DISABLE); 
GdcGeoNdcDcViewportCoeff(200.0f, 320.0f, 200.0f, 240.0f); 
GdcGeoNdcDcDepthCoeff(100.f, 32768.0f); 

GdcGeoViewVolumeXY Clipf(-2.0f, 2.0f, -1.25f, 1.25f); 
GdcGeoViewVolumeZClipf(-1.Of, 1.0f); 
GdcGeoViewVolumeWminClipf(wmin); 
GdcDrawClipFrame(0, 0, 640, 480); 
GdcSetAttrMisc(GDC_CLIP, (GDC_CLIP_X_ON|GDC_CLIP_Y_ON)); 
GdcSetAttrSurf(GDC_DEPTH_TEST, GDC_DISABLE); 
GdcSetAttrSurf(GDC_SHADE_MODE, GDC_SHADE_FLAT); 
GdcSetAttrSurf(GDC_TEXTURE_SELECT,GDC_SELECT_PLAIN); 
GdcGeoLoadMatrixf(fMat1 0); 
GdcColor(0x7c00); 
GdcGeoPrimType(GDC_TRIANGLE_STRIP); 
GdcGeoDrawVertex2Df(-1.0f, 5.0f); 
GdcGeoDrawVertex2Df(-1 .0f,-5.0f); 
( 
( 


GdcGeoDrawVertex2Df( 1.0f, 5.0f); 
GdcGeoDrawVertex2Df( 1.0f,-5.0f); 
GdcGeoPrimEnd(); 


/* When using display list */ 
0x41000000 /* Type:G_Viewport */ 


0x42480000 /*X_Scaling */ 

0x43A00000 /*X_Offset */ 

0x42480000 /*Y_Scaling */ 

0x43700000 /*Y_Offset */ 

0x41000000 /* Type:G_DepthRange */ 

0x42C 80000 /*Z_Scaling */ 

0x47000000 *Z_Offset */ 

0x44000000 /* Type:G_ViewVolumeXYClip */ 
0xC0000000 /*XMIN */ 

0x40000000 /*XMAX */ 

OxBFA00000 /*YMIN */ 

Ox3FA0000 [*YMAX */ 

0x45000000 /*G_ViewClipZ*/ 

OxBF800000 /*ZMIN */ 

0x3F800000 /*ZMAX */ 

0x46000000 /*G_ViewClipW*/ 

0x3089705F /*WMIN */ 

OxF1040115 /* Type: Set Register, data count: 4, address: 454 =>CXMIN */ 
0x00000000 /* Rendering clip XMIN setting */ 
0x00000280 /* Rendering clip XMAX setting */ 
0x00000000 /* Rendering clip YMIN setting */ 
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0x000001E0 
0xF1010108 
0x00008300 
0xF1012010 
0x00000001 
0xF101010A 
0x00000600 
0x43000000 
O0xBF800000 
0x00000000 
0x00000000 
0x00000000 
0x00000000 
0xBE31D0C8 
OxBF7C1C61 
0x00000000 
0x00000000 
0x00000000 
0x00000000 
O0x3DCCCCCD 
0x00000000 
0x3F7C1C61 
0xBE31D0C8 
0x40A00000 
0xF1010120 
0x00007C00 
0x21070000 
0x30000000 
0xBF800000 
0xC0A00000 
0x30000000 
0x3F800000 
0x40A00000 
0x30000000 
0x3F800000 
O0xC0A00000 
0x23000000 
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/* Rendering clip YMAX setting */ 
/* Type: Set Register, data count: 1, address: 420 =>MDRO */ 
/* Rendering clip on setting */ 
/* Type: Set Register, data count: 1, address: 8040 =>GMDRO */ 
/* Vertex parameter setting */ 
/* Type: Set Register, data count: 1, address: 428 =>MDR2 */ 
/* Triangle rendering mode setting */ 
/* Type:G_LoadMatrix */ 
/*Matrix_a0 */ 
/*Matrix_a1 */ 
/*Matrix_a2 */ 
/*Matrix_a3 */ 
/*Matrix_b0 */ 
/*Matrix_b1 */ 
/*Matrix_b2 */ 
/*Matrix_b3 */ 
/*Matrix_cO */ 
/*Matrix_c1 */ 
/*Matrix_c2 */ 
/*Matrix_c3 */ 
/*Matrix_dO */ 
/*Matrix_d1 */ 
/*Matrix_d2 */ 
/*Matrix_d3 */ 
/* Type: Set Register, data count: 1, address: 480 =>FC */ 
/* Foreground color setting */ 
/*Type:G_Begin Command:Triangle_Strip*/ 
/*Type:G_Vertex */ 
/*float xO */ 
/*float yO */ 
/*Type:G_Vertex */ 
/*float x1 */ 
/*float y1 */ 
/*Type:G_Vertex */ 
/*float x2 */ 
/*float y2 */ 
/*Type:G_End */ 
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5.4 Drawing Sprite Image Using Orchid 


The following describes how to draw sprite images, which are image expression techniques often used in 
amusement systems, like games, using Orchid. 


The drawing of sprite images means that only the desired color is drawn without drawing a color of the 2D 
image. 


Original 2D image Image before drawing 


Image after drawing 


Previous color remains without drawing 


There are two drawing methods for sprite images. 
1. Drawing using BLT function 
2. Drawing using texture mapping function 


5.4.1 Drawing using BLT function 


This is used to draw the original 2D image without rotating or zooming in or out, without drawing the 
background color of the original data to draw the desired image. 


See Section 4.6.2.2 for details regarding how to draw. 
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5.4.2 Drawing using texture mapping function 


This is used to draw the original 2D image by rotating or zooming in or out, without drawing the 
background color of the original data to draw the desired image. Refer to 8.5.2 in the MB86291 <Orchid> 
Specifications for details regarding the “stencil” method. 


Note that when the size of the original 2D image exceeds 64 x 64 pixels, arrange to the size of the sprite 
image to draw. 


e Draws referring to the texture data on the graphics memory as it is. 


e Separates sprite images and loads the texture data on the graphics memory to the Orchid internal 
TexRAM. While referencing the internal, TexRam the application controls the two drawing methods to 
allow high speed drawing. 


See “XXXX” and “XXXX” for details regarding drawing performance. 


5.4.2.1 Drawing by referring to texture data on graphics memory 


<Program example> 
e 256 x 256 2D image has been stored on the graphics memory (0X12C000) on Orchid. 
(The background color bit15 is “0”, other pixel color bit15 are “1”.) 
e Drawing 256 x 256 sprites 


/* When using driver function */ 
float fMat[] = { 1.0f, 0.f, 0.f, O.f, O.f, 1.0f,0.f, 0. f, 

0.f, 0.f, 1.0f, 0.0f, 0.f, 0.f, 0.f, 1.0f}; 
GdcGeoSetAttrMisc(GDC_GEO_VTX_ST,GDC_ENABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_COL,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_Z,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_IN_FORMAT,GDC_GEO_FLOAT_INPUT); 
GdcSetAttrSurf(GDC_TEXTURE_SELECT,GDC_SELECT_TEXTURE); 
GdcSetAttrSurf(GDC_DEPTH_TEST,GDC_DISABLE); 
GdcSetAttrSurf(GDC_DEPTH_FUNC,GDC_DEPTH_LEQUAL); 
GdcSetAttrSurf(GDC_SHADE_MODE,GDC_SHADE_FLAT); 
GdcSetAttrSurf(GDC_ BLEND MODE,GDC BLEND ALPHA); 
GdcSetAttrTexture(GDC_TEXTURE_PERSPECTIVE,GDC_DISABLE); 
GdcSetAttrTexture(GDC_TEXTURE_FILTER,GDC_TEXTURE_POINT); 
GdcSetAttrTexture(GDC_TEXTURE_WRAP_S,GDC_TEXTURE_CLAMP); 
GdcSetAttrTexture(GDC_TEXTURE_WRAP_T,GDC_TEXTURE_CLAMP); 
GdcSetAttrTexture(GDC_TEXTURE_BLEND,GDC_TEXTURE_STENCIL); 
GdcSetAttrTexture(GDC TEXTURE ALPHA,GDC TEXTURE ALPHA STENCIL); 
GdcGeoLoadMatrixf(fMatP); 

GdcGeoNdcDcViewportCoeff(1.0f, 320.0f, 1.0f, 240.0f); 
GdcGeoViewVolumeXYClipf(min, max, min, max); 
GdcTextureMemoryMode(GDC_TEX MEM MODE EXT); 


GdcTextureDimension(0x12C000,256,256); 
GdcGeoPrimType(GDC_TRIANGLE_FAN); 


GdcGeoTexCoord2DNf(0.0f,0.0f); 
GdcGeoDrawVertex2Df(-128.0f, -128.0f); 
GdcGeoTexCoord2DNf(0.0f,1.0f); 
GdcGeoDrawVertex2Df(-128.0f, 128.0f); 
GdcGeoTexCoord2DNf(1.0f, 1.0f); 
GdcGeoDrawVertex2Df(128.0f, 128.0f); 
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GdcGeoTexCoord2DNf(1.Of,0.0f); 
GdcGeoDrawVertex2Df( 128.0f, -128.0f); 
GdcGeoPrimEnd(); 


OxF101010A 
0x20000698 
0xF101010B 
0x00120000 
0xF1012010 
0x00000008 
0x43000000 
0x3F800000 
0x00000000 
0x00000000 
0x00000000 
0x00000000 
0x3F800000 
0x00000000 
0x00000000 
0x00000000 
0x00000000 
0x00000000 
0x3F800000 
0x00000000 
0x00000000 
0x00000000 
0x3F800000 
0x41000000 
0x3F800000 
0x43A00000 
0x3F800000 
0x43700000 
0x44000000 
OxFF7FFFFF 
Ox7F7FFFFF 
OxFF7FFFFF 
Ox7F7FFFFF 
0xF1010113 
0x0012C000 
0xF1010119 
0x01000100 
0x21180000 
0x30000000 
0xC3000000 
0xC3000000 
0x00000000 
0x00000000 
0x30000000 
0xC3000000 
0x43000000 
0x00000000 
0x3F800000 
0x30000000 
0x43000000 


/* When using display list */ 


/* Type: Set Register, data count: 1, address: 428 =>MDR2 */ 
/* Polygon drawing mode setting */ 
/* Type: Set Register, data count: 1, address: 42C =>MDR@ */ 
/* Texture mode setting */ 
/* Type: Set Register, data count: 1, address: 40 =>GMDRO */ 
/* Geometry mode setting */ 
/* Type:G_LoadMatrix */ 
/*Matrix_a0 */ 
/*Matrix_a1 */ 
/*Matrix_a2 */ 
/*Matrix_a3 */ 
/*Matrix_b0 */ 
/*Matrix_b1 */ 
/*Matrix_b2 */ 
/*Matrix_b3 */ 
/*Matrix_cO */ 
/*Matrix_c1 */ 
/*Matrix_c2 */ 
/*Matrix_c3 */ 
/*Matrix_dO */ 
/*Matrix_d1 */ 
/*Matrix_d2 */ 
/*Matrix_d3 */ 
/* Type:G_Viewport */ 
/*X_Scaling */ 
/*X_Offset */ 
/*Y_Scaling */ 
/*Y_Offset */ 
/* Type:G_ViewVolumeXYClip */ 
/*XMIN */ 
/*XMAX */ 
/*YMIN */ 
/*YMAX */ 
/* Type: Set Register, data count: 1, address: 44C =>TBR */ 
/* Texture memory address setting */ 
/* Type: Set Register, data count: 1, address: 464 =>TXS */ 
/* Texture size setting */ 
/*Type:G_Begin Command:Triangle_Fan.Int*/ 
/*Type:G_Vertex */ 
/*float xO */ 
/*float yO */ 
/*float sO */ 
/*float tO */ 
/*Type:G_Vertex */ 
/*float x1 */ 
/*float y1 */ 
/*float s1 */ 
/*float t1 */ 
/*Type:G_Vertex */ 
/*float x2 */ 
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0x43000000 
0x3F800000 
0x3F800000 
0x30000000 
0x43000000 
0xC3000000 
0x3F800000 
0x00000000 
0x23000000 


/*float y2 */ 
/*float s2 */ 
/*float t2 */ 
/*Type:G_Vertex */ 
/*float x3 */ 
/*float y3 */ 
/*float s3 */ 
/*float t3 */ 
/*Type:G_End */ 


85 


me) 
FUJITSU 


MB86292 ORCHID APPLICATION NOTE 


5.4.2.2 Drawing by separating sprite images and loading texture data to internal TexRAM 


If the 2D image size exceeds 64 x 64, it divides the sprite image, loads the texture data on the graphics 
memory to the Orchid internal TexRAM and while referencing the internal TexRAM, it draws, which 
achieves high speed processing, based on the sprint image size. 


Specifically, a 256 x 256 2D image is divided into 16 and into 16 for sprite images to be drawn. 


1 is loaded to the internal TexRAM, draws A, 2 is loaded to the internal TexRAM, draws B, etc. 


And 16 is loaded to the internal TexRAM, draws P. 


64 
a 


fos 


256 


256 


Original 2D image Spring image to be drawn 


<Program example> 
e A256 x 256 2D image is stored on the graphics memory (0OX12C000) on Orchid. 
(The background color bit15 is “O”, other pixel color bit 15 are “1”.) 
e Draws 256 x 256 sprites 
e Tex data is loaded to the internal TexRAM and draws by referring the internal TexRAM. 


/* When using driver function */ 
float fMat[] = { 1.0f, 0.f, 0.f, O.f, O.f, 1.0f,0.f, 0. f, 

0.f, 0.f, 1.0f, 0.0f, 0.f, 0.f, O.f, 1.0f}; 
GdcGeoSetAttrMisc(GDC_GEO_VTX_ST,GDC_ENABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_COL,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_VTX_Z,GDC_DISABLE); 
GdcGeoSetAttrMisc(GDC_GEO_IN_FORMAT,GDC_GEO_FLOAT_INPUT); 
GdcSetAttrSurf(GDC_TEXTURE_SELECT,GDC_SELECT_TEXTURE); 
GdcSetAttrSurf(GDC_DEPTH_TEST,GDC_DISABLE); 
GdcSetAttrSurf(GDC_DEPTH_FUNC,GDC_DEPTH_LEQUAL); 
GdcSetAttrSurf(GDC_SHADE_MODE,GDC_SHADE_FLAT); 
GdcSetAttrSurf(GDC BLEND MODE,GDC BLEND ALPHA); 
GdcSetAttrTexture(GDC_TEXTURE_PERSPECTIVE,GDC_DISABLE); 
GdcSetAttrTexture(GDC_TEXTURE_FILTER,GDC_TEXTURE_POINT); 
GdcSetAttrTexture(GDC_TEXTURE_WRAP_S,GDC_TEXTURE_CLAMP); 
GdcSetAttrTexture(GDC_TEXTURE_WRAP_T,GDC_TEXTURE_CLAMP); 
GdcSetAttrTexture(GDC_TEXTURE_BLEND,GDC_TEXTURE_STENCIL); 


GdcSetAttrTexture(GDC TEXTURE ALPHA,GDC TEXTURE ALPHA STENCIL); 
GdcGeoLoadMatrixf(fMatP); 
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GdcGeoNdcDcViewportCoeff(1.0f, 320.0f, 1.0f, 240.0f); 
GdcGeoViewVolumeXYClipf(min, max, min, max); 
GdcTextureMemoryMode(GDC TEX MEM MODE INT); 
GdcTextureDimension(0,64,64); 


for(i=0;i<4;i++){ 


for (j=0;j<4;j++){ 
XO = -128.0f + 647i; 
YO = -128.0f + 64°}; 
GdcBitTexture(TEXADR,256,(64*i),(64*j),64,64, 0); 
GdcGeoPrimType(GDC_TRIANGLE_FAN); 


GdcGeoTexCoord2DNf 
GdcGeoDrawVertex2Df 
GdcGeoTexCoord2DNf 
GdcGeoDrawVertex2Df 
GdcGeoTexCoord2DNf 
GdcGeoDrawVertex2Df 
GdcGeoTexCoord2DNf 
GdcGeoDrawVertex2Df 


= 


0.0f,0.0f); 

XO, YO); 

0.0f,s); 

X0,(Y0+64.0f)); 

S,S); 
(X0+64.0f),(Y0+64.0f)); 
s,0.0f); 

(X0+64.0f), YO); 


mom Pe me 


GdcGeoPrimEnd(); 


OxF101010A 
0x20000698 
0xF101010B 
0x00120000 
0xF1012010 
0x00000008 
0x43000000 
0x3F800000 
0x00000000 
0x00000000 
0x00000000 
0x00000000 
0x3F800000 
0x00000000 
0x00000000 
0x00000000 
0x00000000 
0x00000000 
0x3F800000 
0x00000000 
0x00000000 
0x00000000 
0x3F800000 
0x41000000 
0x3F800000 
0x43A00000 
0x3F800000 
0x43700000 
0x44000000 
OxFF7FFFFF 
Ox7F7FFFFF 


/* When using display list */ 


/* Type: Set Register, data count: 1, address 
/* Polygon drawing mode setting */ 
/* Type: Set Register, data count: 1, address 
/* Texture mode setting */ 
/* Type: Set Register, data count: 1, address 
/* Geometry mode setting */ 
/* Type:G_LoadMatrix */ 
/*Matrix_a0 */ 
/*Matrix_a1 */ 
/*Matrix_a2 */ 
/*Matrix_a3 */ 
/*Matrix_b0 */ 
/*Matrix_b1 */ 
/*Matrix_b2 */ 
/*Matrix_b3 */ 
/*Matrix_cO */ 
/*Matrix_c1 */ 
/*Matrix_c2 */ 
/*Matrix_c3 */ 
/*Matrix_dO */ 
/*Matrix_d1 */ 
/*Matrix_d2 */ 
/*Matrix_d3 */ 
/* Type:G_Viewport */ 
/*X_Scaling */ 
/*X_Offset */ 
/*Y_Scaling */ 
/*Y_Offset */ 
/* Type:G_ViewVolumeXYClip */ 
/*XMIN */ 
/*XMAX */ 
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: 428 =>MDR2 */ 
: 42C =>MDR3 */ 


: 40 =>GMDRO */ 


MB86292 ORCHID APPLICATION NOTE 


OxFF7FFFFF 
Ox7F7FFFFF 
0xF101010B 
0x00120001 
0xF1010119 
0x00400040 
OxF101011B 
0x00000000 
0x13480000 
0x0012C000 
0x00000100 
0x00000000 
0x00400040 
0x00000000 
0x21180000 
0x30000000 
0xC3000000 
0xC3000000 
0x00000000 
0x00000000 
0x30000000 
0xC3000000 
0xC2800000 
0x00000000 
0x3F800000 
0x30000000 
0xC 2800000 
0xC2800000 
0x3F800000 
0x3F800000 
0x30000000 
0xC2800000 
0xC3000000 
0x3F800000 
0x00000000 
0x23000000 


/Repeated 


PYMIN */ 
’YMAX */ 


/* Type: Set Register, data count: 1, address: 42C =>MDR3 */ 


/* Texture mode setting */ 


/* Type: Set Register, data count: 1, address: 464 =>TXS */ 


/* Texture size setting */ 


/* Type: Set Register, data count: 1, address: 46C =>TOA */ 


/* Texture memory address setting */ 
/*Type:BltTexureP Command:LoadTexture*/ 
/*SrcADDR*/ 
/*SrcStride*/ 
/*SrcRectYs SrcRectXs*/ 
/*BRsizeY BRsize*/ 
/*DestOffset*/ 
/*Type:G_Begin Command:Triangle_Fan.Int*/ 
/*Type:G_Vertex */ 
/*float xO */ 
/*float yO */ 
/*float sO */ 
/*float tO */ 
/*Type:G_Vertex */ 
/*float x1 */ 
/*float y1 */ 
/*float s1 */ 
/*float t1 */ 
/*Type:G_Vertex */ 
/*float x2 */ 
/*float y2 */ 
/*float s2 */ 
/*float t2 */ 
/*Type:G_Vertex */ 
/*float x3 */ 
/*float y3 */ 
/*float s3 */ 
/*float t3 */ 
/*Type:G_End * 
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5.4.2.3 Sprite image drawing performance 

The following describes the drawing performance of 5.4.2.7 and 5.4.2.2. 
e Time all objects are drawn 100 times. 

e Time units are usec. 


e External Tex is the drawing time (equivalent to 5.4.2.7) when referring Tex data on the graphics memory 
to draw 2D image data. 


e Internal Tex handles Tex data as a unit of 64 x 64, stores it in the internal TexRAM and divides 
polygons (For Tex size of 256 x 256, they are divided into 16, for 128 x 128, they are divided into 4) to 
draw. This is the time to draw including the time to load Tex from the graphics memory. (equivalent to 
5.4.2.2) 


e +Z is the time to draw when the geometery and rending Z and W (path) attribures are ON. 


For Tex size of 256 x 256 
Filter Polygon Size (Pixels) External Tex Internal Tex External Tex + Z | Internal Tex + Z 
256*256 65536 1199120 127718 1311783 220794 
128°128 16384 327364 76546 346900 103883 
64*64 4096 89066 63670 92332 71787 
Point 55*55 3025 65901 62472 68593 68782 
50*50 2500 54510 61915 56727 67108 
32°32 1024 22519 59900 23547 62156 
16°16 256 5840 58020 6205 58888 
256*256 65536 1886935 218936 1988065 298688 
128°128 16384 648378 105110 671527 126268 
64*64 4096 178150 72675 183427 78790 
Bilinear 40*40 1600 66129 61120 67328 64811 
37°37 1369 56245 60946 57332 63826 
32*32 1024 46660 61061 47877 63228 
16°16 256 11844 58389 12214 59164 


For Tex size of 128 x 128 


Filter Polygon Size (Pixels) External Tex Internal Tex External Tex + Z | Internal Tex + Z 
128°128 16384 290857 31772 318667 54850 

64*64 4096 75677 18955 83487 25726 

Point 32°32 1024 20877 15723 22217 17719 
28*28 784 16266 15477 17342 17013 

24*24* 576 12339 15248 12980 16309 

16°16 256 5837 14781 6134 15386 

128°128 16384 451236 54532 483523 74585 

64*64 4096 151946 26050 159623 31430 

Bilinear 32*32 1024 41755 17961 43800 19478 
24*24 576 23205 15663 23960 16774 

16°16 256 11394 15068 11835 15610 
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10° 


10° 


Drawing time (usec) 


1000 


—<s— External Tex 
—=— Internal Tex 
——<——— External Tex + Z 
————~ External Tex + Bilinear 
———— Internal Tex + Z 


——Hr= Internal Tex + Bilinear 
~——@-— External Tex + Z + Bilinear 
—l— Internal Tex + Z + Bilinear 


100 


1000 


104 


Polygon size 


Graph 1: 


Tex Size 256 x 256 


10° 


For Tex sizes of 256 x 256 (loading texture data to the internal TexRAM for 16 times), near the point 
where the polygon size (the size of the sprite display) exceeds 1000 to 1200 pixels (31 x 31 to 35 x 35), it 
divides polygons, loads to the internal TexRAM to draw at high speed. 


90 


Eo) 
FUJITSU 


10° 7 tre r Fete Pe Pb eee 


—s— External Tex 
—=— Internal Tex 

External Tex + Z 
———— External Tex + Bilinear 
———— Internal Tex + Z 
——tr= Internal Tex + Bilinear 
—~@-—— External Tex + Z + Bilinear 
—H—_ Internal Tex + Z + Bilinear 


=e 
oO 
oO 


Drawing time (usec) 


— 
oO 
b 


1000 eee eee = eee ae 
1000 1000 10° 
Polygon size 


Graph 2: Tex Size 128 x 128 


For Tex sizes of 128 x 128 (loading texture data to the internal TexRAM for 4 times), near the point where 
the polygon size (the size of the sprite display) exceeds 300 to 1000 pixels (17 x 17 to 31 x 31), it divides 
polygons, loads to the internal TexRAM to draw at high speed. 
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@ Reference 


The following shows the time (usec) for Bit Texture (to load textures from the graphics memory to the 
internal TexRAM) and the BLT Copy Alternate time (usec) (copying rectangle area between graphics 
memories) for reference. 


e BiltTexture: 


The following one time loads 64 x 64 (=4096) pixels from the graphics memory to the internal 
TexRAM. 


100 times (actual measured value) 3325 
Per one time 33.25 
For 256 x 256: 33.25 x 16 532 
For 128 x 128: 33.25 x 4 133 


¢ BLT Copy Alternate: 
Drawing performance when copied 100 times. 


Copy size Copy time 
256*256 65536 97599 
128*128 16384 24650 
64*64 4096 6379 
32*32 1024 1848 
16°16 256 654 
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5.5. Orchid Geometry and Rendering Performance 


The following shows Orchid geometry and rendering performance. 


Use these as general performance values for developing applications. 


Measuring method: 


Orchid operating frequency: 100 MHz 


Graphics memory bus width: 64 bits 


Transfer mode: Local mode 


(Writes and draws the display list from the graphics memory.) 


@ Orchid geometry performance 


Measuring method: 
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Average values when drawing 100 Triangle_FAN.int 10 times to a5 x 5 pixel area 


Performance 
Vertex parameter 
K Polygon/sec. K Polygon/frame *1 K Polygon/frame *2 
XY 805.15298 26.83843 13.41922 
XYZ 354.10765 11.80359 5.90179 
XYRGB 206.73972 6.89132 3.44566 
XYZRGB 180.50542 6.01685 3.00842 
XYST 300.30030 10.01001 5.00501 
XYRGBST 137.77900 4.59263 2.29632 
XYZSTQ 207.42585 6.91419 3.45710 
XYZRGBSTQ 122.10012 4.07000 2.03500 


*1: In terms of 30 frames/sec. 
*2: In terms of 60 frames/sec. 
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@ Orchid rendering performance 


Measuring method: 


Average values when drawing 100 Triangle_FAN.int 10 times to a triangle 25 x 20 pixel rarea. 


Attribute Performance 
Alpha blend Vertex parameter K Polygon/sec. Mpixel/sec. 
XY 253.74271 63.43568 
XYZ 120.93361 30.23340 
XYRGB 200.00000 50.00000 
XYZRGB 117.64706 29.41176 
XYST 218.81838 54.70460 
Byovided XYRGBST 134.39054 33.59763 
XYZSTQ 116.07661 29.01915 
XYZRGBSTQ 112.79044 28.19761 
XYST(_) 22.39240 5.59810 
XYZSTQ (_ ) 19.73671 4.93418 
XYRGBST (__) 22.26130 5.56533 
XYZRGBST (_) 19.66994 4.91748 
XY 168.91892 42.22973 
XYZ 81.28099 20.32025 
XYRGB 154.67904 38.66976 
XYZRGB 80.64516 20.16129 
XYST 155.15904 38.78976 
Not provided XYRGBST 133.68984 33.42246 
XYZSTQ 80.59317 20.14829 
XYZRGBSTQ 79.85945 19.96486 
XYST(__) 20.61176 5.15294 
XYZSTQ (_ ) 18.89966 4.72492 
XYRGBST (__) 20.55837 5.13959 
XYZRGBST ( ) 18.86010 4.71502 
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